列表中具有不同属性的对象数量

Number of objects with distinct property in a list

本文关键字:对象 属性 列表      更新时间:2023-09-26

这是一个简单的数据集

data = [
    {'artist':'a','song':'a'},
    {'artist':'a','song':'b'},
    {'artist':'a','song':'c'},
    {'artist':'b','song':'d'},
    {'artist':'b','song':'e'},
    {'artist':'c','song':'f'},
    {'artist':'d','song':'g'},
    {'artist':'d','song':'h'},
    {'artist':'d','song':'i'}
];

在javascript或jQuery中是否有任何本地函数可以让我在简洁的表达式中获得不同艺术家的数量?

要获取不同艺术家的数量,您可以使用以下命令:

Object.keys(data.reduce(function(p, c) { p[c.artist] = 1 ; return p }, {})).length

这是一个单行代码,它累加对象pc.artist的不同值,然后计算有多少个键。

您可以这样尝试:

var array = [{"artist":"a","song":"a"}, {"artist":"a","song":"b"}, {"artist":"a","song":"c"}]
var unique = {};
var distinct = [];
    for( var i in array ){
     if( typeof(unique[array[i].song]) == "undefined"){
      distinct.push(array[i].song);
     }
     unique[array[i].song] = 0;
    }
var d = document.getElementById("d");
d.innerHTML = "" + distinct;

JSFIDDLE演示

试试这个,演示

在这里
data = [
    {'artist':'a','song':'a'},
    {'artist':'a','song':'b'},
    {'artist':'a','song':'c'},
    {'artist':'b','song':'d'},
    {'artist':'b','song':'e'},
    {'artist':'c','song':'f'},
    {'artist':'d','song':'g'},
    {'artist':'d','song':'h'},
    {'artist':'d','song':'i'}
];
newdata=[];
$.each(data, function(index,value){
newdata[index]=data[index].artist;
});
alert($.unique(newdata));