自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

小技巧 | 使用 Object.groupBy() 輕松分組JavaScript數(shù)組

開發(fā) 前端
Object.groupBy() 是一種靜態(tài)方法,按屬性對數(shù)組數(shù)據(jù)進行分組。只需傳入兩個參數(shù):數(shù)組和回調(diào)函數(shù)。對數(shù)組中的每個元素執(zhí)行回調(diào)函數(shù)以確定其所屬的組。

使用 Object.groupBy() 來對數(shù)據(jù)進行分組,而不用任何循環(huán)

在 JavaScript 中分組數(shù)據(jù)曾經(jīng)是個痛苦的過程,我們不得不遍歷對象并將它們放入單獨的數(shù)組中,但現(xiàn)在,多虧了新的 Object.groupBy() 方法,分組數(shù)據(jù)變得輕而易舉。

Object.groupBy() 是一種靜態(tài)方法,按屬性對數(shù)組數(shù)據(jù)進行分組。只需傳入兩個參數(shù):數(shù)組和回調(diào)函數(shù)。對數(shù)組中的每個元素執(zhí)行回調(diào)函數(shù)以確定其所屬的組。

假設(shè)下面的數(shù)組是我們的數(shù)據(jù)

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,
  },
];

如果我們想根據(jù)它們的 major 分組,那么我們會使用如下方法

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

這將給我們以下輸出

圖片圖片

現(xiàn)在假設(shè)我們想根據(jù)年齡大于 10 來分組

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

圖片圖片

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

圖片圖片

責(zé)任編輯:武曉燕 來源: 獨立開發(fā)者張張
相關(guān)推薦

2024-03-04 06:37:55

TypeScript類型聲明靜態(tài)方法

2023-11-03 07:21:40

Javascript數(shù)組分組

2023-09-21 10:09:10

JavaScript數(shù)組分組

2024-07-24 13:02:31

LodashJS分組

2021-09-29 06:03:37

JavaScriptreduce() 前端

2011-07-15 17:35:19

JavaScript

2022-07-04 08:51:43

條件語句JavaScript

2011-05-07 15:15:46

復(fù)印機

2021-03-17 08:53:21

JavaScript開發(fā)代碼

2020-08-21 17:40:15

JavaScript開發(fā) 技巧

2021-03-15 08:13:19

JavaScript開發(fā)代碼

2019-12-20 14:32:55

JavaScript函數(shù)開發(fā)

2010-10-21 15:57:37

SQL Server無

2024-02-01 18:06:04

Python編程系統(tǒng)

2020-12-14 08:30:02

JavaScript開發(fā)代碼

2020-05-17 16:19:59

JavaScript代碼開發(fā)

2020-09-26 21:50:26

JavaScript代碼開發(fā)

2023-12-05 07:59:08

JS小技巧數(shù)組對象去重

2024-01-03 08:53:35

JavaScrip編程語言NodeJS

2010-11-10 11:27:40

SQL Server重
點贊
收藏

51CTO技術(shù)棧公眾號