对数组中的对象进行分组的最有效方法是什么?
例如,给定这个对象数组:
[ { Phase: "Phase 1", Step: "Step 1", Task: "Task 1", Value: "5" }, { Phase: "Phase 1", Step: "Step 1", Task: "Task 2", Value: "10" }, { Phase: "Phase 1", Step: "Step 2", Task: "Task 1", Value: "15" }, { Phase: "Phase 1", Step: "Step 2", Task: "Task 2", Value: "20" }, { Phase: "Phase 2", Step: "Step 1", Task: "Task 1", Value: "25" }, { Phase: "Phase 2", Step: "Step 1", Task: "Task 2", Value: "30" }, { Phase: "Phase 2", Step: "Step 2", Task: "Task 1", Value: "35" }, { Phase: "Phase 2", Step: "Step 2", Task: "Task 2", Value: "40" } ]
我正在表格中显示此信息。我想按不同的方法进行分组,但我想对值进行求和。
我使用 Underscore.js 来实现其 groupby 功能,这很有帮助,但并不能解决全部问题,因为我不希望它们“拆分”而是“合并”,更像是 SQL group by
方法。
我正在寻找能够计算具体值的总和(如果需要的话)。
因此,如果我执行 groupby Phase
,我希望收到:
[ { Phase: "Phase 1", Value: 50 }, { Phase: "Phase 2", Value: 130 } ]
如果我执行 groupy Phase
/ Step
,我会收到:
[ { Phase: "Phase 1", Step: "Step 1", Value: 15 }, { Phase: "Phase 1", Step: "Step 2", Value: 35 }, { Phase: "Phase 2", Step: "Step 1", Value: 55 }, { Phase: "Phase 2", Step: "Step 2", Value: 75 } ]
是否有一个有用的脚本,或者我应该坚持使用 Underscore.js,然后循环遍历结果对象来自己计算总计?
使用 ES6 Map 对象:
关于地图: https://developer.mozilla.org/en-US /docs/Web/JavaScript/Reference/Global_Objects/Map
如果您想避免使用外部库,您可以简洁地实现
groupBy()
的普通版本,如下所示: