列表中具有不同属性的对象数量
Number of objects with distinct property in a list
这是一个简单的数据集
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
这是一个单行代码,它累加对象p
中c.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));
相关文章:
- 如何从对象的原型方法访问JavaScript对象属性
- 如何将数组项添加到对象属性中
- 设置嵌套对象属性的更好方法
- JavaScript管理具有重复属性名称的对象属性
- 如何使用element.myobj.prop等具有对象属性的元素
- 如何使用(this)访问Angular 2 http rxjs catch函数中的对象属性
- Es6:能够在设置/更新/删除对象属性时调用自定义方法
- 如何在AngularJS工厂中正确声明对象属性
- 如何使用object.assign()从其他对象引用基本对象属性
- 使用XPath样式访问Javascript JSON对象属性
- 将javascript对象(属性+值)合并到一个对象中
- 数组:使对象属性成为数组键
- 无法从JavaScript中的函数调用对象属性
- Google Closure Advanced |无法识别对象属性|动态属性
- Javascript从匿名函数访问外部对象属性
- 从函数更改对象属性
- 如何从字符串变量访问对象属性
- 从嵌套对象属性中获取排除某个值的最高值
- 在Aurelia computeds中,当设置依赖关系时,如何声明对对象属性的依赖关系
- 传递数量不确定的可能嵌套的对象属性