如何解决对对象数组进行分组的最有效方法
如果你想避免使用外部库,你可以简洁地实现一个 vanilla 版本,groupBy()
如下所示:
var groupBy = function(xs, key) {
return xs.reduce(function(rv, x) {
(rv[x[key]] = rv[x[key]] || []).push(x);
return rv;
}, {});
};
console.log(groupBy(['one', 'two', 'three'], 'length'));
// => {3: ["one", "two"], 5: ["three"]}
解决方法
对数组中的对象进行分组的最有效方法是什么?
例如,给定这个对象数组:
[
{ Phase: "Phase 1",Step: "Step 1",Task: "Task 1",Value: "5" },{ Phase: "Phase 1",Task: "Task 2",Value: "10" },Step: "Step 2",Value: "15" },Value: "20" },{ Phase: "Phase 2",Value: "25" },Value: "30" },Value: "35" },Value: "40" }
]
我将在表格中显示此信息。我喜欢按不同的方法进行分组,但我想对这些值求和。
我将 Underscore.js 用于它的 groupby 函数,这很有帮助,但并没有完成全部技巧,因为我不希望它们“拆分”而是“erged”,更像是
SQLgroup by
方法.
我要查找的内容将能够汇总特定值(如果需要)。
所以如果我做了 groupby Phase
,我想收到:
[
{ Phase: "Phase 1",Value: 50 },Value: 130 }
]
如果我做了 groupy Phase
/ Step
,我会收到:
[
{ Phase: "Phase 1",Value: 15 },Value: 35 },Value: 55 },Value: 75 }
]
是否有对此有用的脚本,或者我应该坚持使用 Underscore.js,然后循环遍历生成的对象以自己进行总计?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。