Javascript数组计数并将结果添加到变量

时间:2016-10-07 09:08:19

标签: javascript

我有一个这样的数组:

var obj = {
    "people": [{
        "id": "100",
        "name": "name 1",
        "desc": "desc 1",
        "class": "a"
    }, {
        "id": "192",
        "name": "name 2",
        "desc": "desc 2",
        "class": "b"
    }, {
        "id": "324",
        "name": "name 3",
        "desc": "desc 3",
        "class": "b"
    }, {
        "id": "324",
        "name": "name 4",
        "desc": "desc 4",
        "class": "a"
    }, {
        "id": "324",
        "name": "name 5",
        "desc": "desc 5",
        "class": "a"
    }]
};

我知道,例如,为了获得类“a”的所有记录,我这样做:

obj.people.filter(function(item) { return item.class === "a" });

但是,如何计算包含“a”类的记录总数?

2 个答案:

答案 0 :(得分:2)

您可以使用返回数组中的Array#length属性。

count = obj.people.filter(function(item) { return item.class === "a" }).length;

或使用Array#reduce并添加比较。

count = obj.people.reduce(function (r, item) { return r + +(item.class === "a") }, 0);

答案 1 :(得分:1)

只需检查length

返回的数组的filter即可
var result = obj.people.filter(function(item) { return item.class === "a" });
console.log( result.length );

或者你可以简单地运行一个告诉你这个计数的循环

var count = 0;
for( var counter = 0; counter < obj.people.length; counter++ )
{
   ( obj.people[ counter ].class === "a" ) && count++;
}
console.log( count );