我有一个按不同类别分组的数组,每个类别都嵌套了更多具有不同值(数值和字符串)的对象,我必须减少这些对象(字符串除外)。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>
单位(整数)加起来很好,但字符串被最后一个迭代字符串属性覆盖。
我想得到这样的结果,如果字符串不同,整数就不会加起来。
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'
}
]
}做这件事最好的方法是什么?
发布于 2016-06-21 10:02:09
最后,这个提议使用一个对象作为对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);
发布于 2016-06-28 04:43:11
我想这也是答案。
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 result = {};
Object.keys(data).forEach(function (key) {
var hash = {};
data[key].forEach(function (v, k) {
isNaN(hash[(k = v.subcategory + v.name)]) ?
(hash[k] = this.push(v) - 1) :
(this[hash[k]].units += v.units);
}, (this[key] = []));
}, result);
console.log(result)
https://stackoverflow.com/questions/37941029
复制相似问题