我有一个按不同类别分组的数组,每个类别都嵌套了更多具有不同值(数字和字符串)的对象,这些对象必须减少(字符串除外)。Reduce可以很好地处理将它们相加的数字值,但它会覆盖仅保留最后一个值的字符串值。
我试图按类别减少对象/词典,并用每个类别的单位总和填充表格,但是如果子类别和名称不同,则不要对它们进行求和。
这是一个演示:
var data = {
'Category xxxx': [
{
units: 1234,
subcategory: 'wolves',
name: 'Starks'
},
{
units: 1345354,
subcategory: 'wolves',
name: 'Starks'
},
{
units: 666,
subcategory: 'dragons',
name: 'Targaryens'
}
],
'Category yyyy': [
{
units: 7783,
subcategory: 'lions',
name: 'Lanisters'
},
{
units: 1267878,
subcategory: 'spires',
name: 'Martells'
}
]
}
var test = _.map(data, function (value, key) {
var returnedData = {
Category: key,
units: _(value).reduce(function (memo, metrics) {
return memo + metrics.units;
}, 0),
subcategory: _(value).reduce(function (memo, metrics) {
return metrics.subcategory;
}, 0),
name: _(value).reduce(function (memo, metrics) {
return metrics.name;
}, 0),
};
return returnedData;
});
console.log(test)
<script src="https://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.8.3/underscore-min.js"></script>
单位(整数)加起来很好,但是字符串被最后一个迭代的string属性覆盖。
我想获得类似这样的东西,如果字符串不同,则不将整数相加。
returnedData = {
'Category xxxx': [
{
units: 1346588,
chivalry: 'wolves',
name: 'Starks'
},
{
units: 666,
subcategory: 'dragons',
name: 'Targaryens'
}
],
'Category yyyy': [
{
clicks: 7783,
subcategory: 'lions',
name: 'Lanisters'
},
{
clicks: 1267878,
subcategory: 'spires',
name: 'Martells'
}
]
}
最好的方法是什么?
最后,该建议使用一个对象作为对该result
对象各项的引用。
如果没有result
可用的对象,则它将创建一个具有所需类别的新对象。对于子类别,它将生成一个元素,该元素将被推送到结果数组。
该计数将hash
作为的元素进行维护result
。
var data = { 'Category xxxx': [{ clicks: 1234, subcategory: 'dogs', name: 'jhon doe' }, { clicks: 1345354, subcategory: 'dogs', name: 'jhon doe' }], 'Category yyyy': [{ clicks: 7783, subcategory: 'frogs', name: 'lanisters' }, { clicks: 1267878, subcategory: 'rats', name: 'perry' }] },
result = {};
Object.keys(data).forEach(function (k) {
var hash = Object.create(null);
if (!result[k]) {
result[k] = [];
}
data[k].forEach(function (a) {
if (!hash[a.subcategory]) {
hash[a.subcategory] = { clicks: 0, subcategory: a.subcategory, name: a.name };
result[k].push(hash[a.subcategory]);
}
hash[a.subcategory].clicks += a.clicks;
});
});
console.log(result);
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句