首页 > web前端 > js教程 > 如何使用普通方法在 JavaScript 中有效地对对象数组进行分组?

如何使用普通方法在 JavaScript 中有效地对对象数组进行分组?

Susan Sarandon
发布: 2024-12-30 12:31:13
原创
279 人浏览过

How Can I Efficiently Group an Array of Objects in JavaScript Using a Vanilla Approach?

对象数组的高效 GroupBy 方法

根据公共属性对对象进行分组是数据处理中的常见任务。此代码片段提供了一种使用普通 JavaScript 方法对数组中的对象进行分组的有效解决方案。

为什么要避免 Underscore.js?

虽然 Underscore.js 提供了 groupBy 函数,但其​​实现可能不如果您需要“合并”结果而不是单独的组,则适合。

自定义 Vanilla JS GroupBy

以下脚本定义一个对对象数组进行操作的 groupBy 函数:

var groupBy = function(xs, key) {
  return xs.reduce(function(rv, x) {
    (rv[x[key]] = rv[x[key]] || []).push(x);
    return rv;
  }, {});
};
登录后复制

用法示例

按“Phase”对对象进行分组:

const data = [
  { Phase: "Phase 1", Step: "Step 1", Task: "Task 1", Value: "5" },
  ...
];
const groupedByPhase = groupBy(data, 'Phase');
登录后复制

groupedByPhase 将包含:

{
  "Phase 1": [
    { Phase: "Phase 1", Step: "Step 1", Task: "Task 1", Value: "5" },
    ...
  ],
  "Phase 2": [
    { Phase: "Phase 2", Step: "Step 1", Task: "Task 1", Value: "25" },
    ...
  ]
}
登录后复制

进一步分组“步骤”:

const groupedByPhaseStep = _(groupedByPhase).values().map(phase => {
  return groupBy(phase, 'Step');
}).value();
登录后复制

groupedByPhaseStep 将包含:

[
  {
    "Phase": "Phase 1",
    "Step": "Step 1",
    "Value": 15
  },
  ...
]
登录后复制

以上是如何使用普通方法在 JavaScript 中有效地对对象数组进行分组?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板