小技巧 | 使用 Object.groupBy() 轻松分组JavaScript数组

开发 前端
Object.groupBy() 是一种静态方法,按属性对数组数据进行分组。只需传入两个参数:数组和回调函数。对数组中的每个元素执行回调函数以确定其所属的组。

使用 Object.groupBy() 来对数据进行分组,而不用任何循环

在 JavaScript 中分组数据曾经是个痛苦的过程,我们不得不遍历对象并将它们放入单独的数组中,但现在,多亏了新的 Object.groupBy() 方法,分组数据变得轻而易举。

Object.groupBy() 是一种静态方法,按属性对数组数据进行分组。只需传入两个参数:数组和回调函数。对数组中的每个元素执行回调函数以确定其所属的组。

假设下面的数组是我们的数据

const studentsArray = [
  {
    name: "John Doe",
    age: 18,
    grade: 12,
    major: "Computer Science",
    gpa: 3.8,
  },
  {
    name: "Jane Doe",
    age: 17,
    grade: 11,
    major: "English",
    gpa: 3.6,
  },
  {
    name: "Michael Smith",
    age: 16,
    grade: 10,
    major: "Mathematics",
    gpa: 4.0,
  },
  {
    name: "Susan Jones",
    age: 15,
    grade: 9,
    major: "History",
    gpa: 3.2,
  },
  {
    name: "David Williams",
    age: 14,
    grade: 8,
    major: "Computer Science",
    gpa: 3.4,
  },
  {
    name: "Mary Brown",
    age: 13,
    grade: 7,
    major: "Mathematics",
    gpa: 3.1,
  },
  {
    name: "Charles Miller",
    age: 12,
    grade: 6,
    major: "History",
    gpa: 3.0,
  },
  {
    name: "Patricia Davis",
    age: 11,
    grade: 5,
    major: "Physical Education",
    gpa: 3.5,
  },
  {
    name: "James Garcia",
    age: 10,
    grade: 4,
    major: "Foreign Language",
    gpa: 3.3,
  },
  {
    name: "Jennifer Johnson",
    age: 9,
    grade: 3,
    major: "Physical Education",
    gpa: 3.7,
  },
];

如果我们想根据它们的 major 分组,那么我们会使用如下方法

Object.groupBy(studentsArray, ({ major }) => major);

这将给我们以下输出

图片图片

现在假设我们想根据年龄大于 10 来分组

Object.groupBy(studentsArray, ({ age }) => age > 10);

图片图片

那么小于 10 的元素将是 false ,大于 10 的元素将是 true 。我们可以用更多的方式来完成我们的工作。

图片图片

责任编辑:武晓燕 来源: 独立开发者张张
相关推荐

2024-03-04 06:37:55

TypeScript类型声明静态方法

2023-11-03 07:21:40

Javascript数组分组

2023-09-21 10:09:10

JavaScript数组分组

2021-09-29 06:03:37

JavaScriptreduce() 前端

2011-07-15 17:35:19

JavaScript

2011-05-07 15:15:46

复印机

2021-03-17 08:53:21

JavaScript开发代码

2022-07-04 08:51:43

条件语句JavaScript

2020-08-21 17:40:15

JavaScript开发 技巧

2010-10-21 15:57:37

SQL Server无

2020-12-14 08:30:02

JavaScript开发代码

2024-02-01 18:06:04

Python编程系统

2019-12-20 14:32:55

JavaScript函数开发

2021-03-15 08:13:19

JavaScript开发代码

2023-12-05 07:59:08

JS小技巧数组对象去重

2010-11-10 11:27:40

SQL Server重

2017-10-30 17:25:11

javascript

2016-05-10 10:16:13

JavaScript技巧

2020-09-26 21:50:26

JavaScript代码开发

2020-05-17 16:19:59

JavaScript代码开发
点赞
收藏

51CTO技术栈公众号