Meh*_*ali 2 javascript arrays json object angularjs
我有以下JSON数组我想创建对象表单状态键计数
[
{
"id": "65:0",
"status": "ORANGE"
},
{
"id": "65:0",
"status": "GREEN"
},
{
"id": "65:0",
"status": "ORANGE"
},
{
"id": "65:0",
"status": "YELLOW"
},
{
"id": "65:0",
"status": "RED"
},
{
"id": "65:0",
"status": "GREEN"
},
{
"id": "65:0",
"status": "GREEN"
},
{
"id": "65:0",
"status": "ORANGE"
},
{
"id": "65:0",
"status": "YELLOW"
},
{
"id": "65:0",
"status": "GREEN"
}
]
Run Code Online (Sandbox Code Playgroud)
想要计算状态键值并创建以下对象
{
'ORANGE' : 3,
'GREEN' : 4,
'YELLOW' : 2,
'RED' : 1,
}
Run Code Online (Sandbox Code Playgroud)
使用Array#reduce方法
var res = data.reduce(function(obj, v) {
// increment or set the property
// `(obj[v.status] || 0)` returns the property value if defined
// or 0 ( since `undefined` is a falsy value
obj[v.status] = (obj[v.status] || 0) + 1;
// return the updated object
return obj;
// set the initial value as an object
}, {})
Run Code Online (Sandbox Code Playgroud)
var data = [{
"id": "65:0",
"status": "ORANGE"
}, {
"id": "65:0",
"status": "GREEN"
}, {
"id": "65:0",
"status": "ORANGE"
}, {
"id": "65:0",
"status": "YELLOW"
}, {
"id": "65:0",
"status": "RED"
}, {
"id": "65:0",
"status": "GREEN"
}, {
"id": "65:0",
"status": "GREEN"
}, {
"id": "65:0",
"status": "ORANGE"
}, {
"id": "65:0",
"status": "YELLOW"
}, {
"id": "65:0",
"status": "GREEN"
}];
var res = data.reduce(function(obj, v) {
obj[v.status] = (obj[v.status] || 0) + 1;
return obj;
}, {})
console.log(res);Run Code Online (Sandbox Code Playgroud)
虽然您可以使用Array#forEach相同代码的方法.
var res = {};
data.forEach(function(v) {
res[v.status] = (res[v.status] || 0) + 1;
})
Run Code Online (Sandbox Code Playgroud)
var data = [{
"id": "65:0",
"status": "ORANGE"
}, {
"id": "65:0",
"status": "GREEN"
}, {
"id": "65:0",
"status": "ORANGE"
}, {
"id": "65:0",
"status": "YELLOW"
}, {
"id": "65:0",
"status": "RED"
}, {
"id": "65:0",
"status": "GREEN"
}, {
"id": "65:0",
"status": "GREEN"
}, {
"id": "65:0",
"status": "ORANGE"
}, {
"id": "65:0",
"status": "YELLOW"
}, {
"id": "65:0",
"status": "GREEN"
}];
var res = {};
data.forEach(function(v) {
res[v.status] = (res[v.status] || 0) + 1;
})
console.log(res);Run Code Online (Sandbox Code Playgroud)