精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

JavaScript 終于原生支持?jǐn)?shù)組分組了!

開發(fā) 前端
在日常開發(fā)中,很多時(shí)候需要對(duì)數(shù)組進(jìn)行分組,每次都要手寫一個(gè)分組函數(shù),或者使用lodash的groupBy函數(shù)。好消息是,JavaScript 現(xiàn)在正在引入全新的分組方法:Object.groupBy和Map.groupBy,以后再也不需要手寫分組函數(shù)了,目前最新版本的 Chrome(117)已經(jīng)支持了這兩個(gè)方法!

以前的數(shù)組分組

假設(shè)有一個(gè)由表示人員的對(duì)象組成的數(shù)組,需要按照年齡進(jìn)行分組。可以使用forEach循環(huán)來實(shí)現(xiàn),代碼如下:

const people = [
  { name: "Alice", age: 28 },
  { name: "Bob", age: 30 },
  { name: "Eve", age: 28 },
];

const peopleByAge = {};

people.forEach((person) => {
  const age = person.age;
  if (!peopleByAge[age]) {
    peopleByAge[age] = [];
  }
  peopleByAge[age].push(person);
});

console.log(peopleByAge);

輸出結(jié)果如下:

{
  "28": [{"name":"Alice","age":28}, {"name":"Eve","age":28}],
  "30": [{"name":"Bob","age":30}]
}

也可以使用reduce方法:

const peopleByAge = people.reduce((acc, person) => {
  const age = person.age;
  if (!acc[age]) {
    acc[age] = [];
  }
  acc[age].push(person);
  return acc;
}, {});

無論哪種方式,代碼都略顯繁瑣。每次都要檢查對(duì)象,看分組鍵是否存在,如果不存在,則創(chuàng)建一個(gè)空數(shù)組,并將項(xiàng)目添加到該數(shù)組中。

使用 Object.groupBy 分組

可以通過以下方式來使用新的Object.groupBy方法:

const peopleByAge = Object.groupBy(people, (person) => person.age);

可以看到,代碼非常簡(jiǎn)潔!

不過需要注意,使用Object.groupBy方法返回一個(gè)沒有原型(即沒有繼承任何屬性和方法)的對(duì)象。這意味著該對(duì)象不會(huì)繼承Object.prototype上的任何屬性或方法,例如hasOwnProperty或toString等。雖然這樣做可以避免意外覆蓋Object.prototype上的屬性,但也意味著不能使用一些與對(duì)象相關(guān)的方法。

const peopleByAge = Object.groupBy(people, (person) => person.age);
console.log(peopleByAge.hasOwnProperty("28"));
// TypeError: peopleByAge.hasOwnProperty is not a function

在調(diào)用Object.groupBy時(shí),傳遞給它的回調(diào)函數(shù)應(yīng)該返回一個(gè)字符串或 Symbol 類型的值。如果回調(diào)函數(shù)返回其他類型的值,它將被強(qiáng)制轉(zhuǎn)換為字符串。

在這個(gè)例子中,回調(diào)函數(shù)返回的是一個(gè)數(shù)字類型的age屬性值,但由于Object.groupBy方法要求鍵必須是字符串或 Symbol 類型,所以該數(shù)字會(huì)被強(qiáng)制轉(zhuǎn)換為字符串類型。

console.log(peopleByAge[28]);
// => [{"name":"Alice","age":28}, {"name":"Eve","age":28}]
console.log(peopleByAge["28"]);
// => [{"name":"Alice","age":28}, {"name":"Eve","age":28}]

使用 Map.groupBy 分組

Map.groupBy和Object.groupBy幾乎做的是相同的事情,只是返回的結(jié)果類型不同。Map.groupBy返回一個(gè)Map對(duì)象,而不是像Object.groupBy返回一個(gè)普通的對(duì)象。

const ceo = { name: "Jamie", age: 40, reportsTo: null };
const manager = { name: "Alice", age: 28, reportsTo: ceo };

const people = [
  ceo
  manager,
  { name: "Bob", age: 30, reportsTo: manager },
  { name: "Eve", age: 28, reportsTo: ceo },
];

const peopleByManager = Map.groupBy(people, (person) => person.reportsTo);

這里根據(jù)人的匯報(bào)上級(jí)將他們進(jìn)行了分組。如果想通過對(duì)象來從這個(gè)Map中獲取數(shù)據(jù),那么要求這些對(duì)象具有相同的身份或引用。這是因?yàn)镸ap在比較鍵時(shí)使用的是嚴(yán)格相等(===),只有兩個(gè)對(duì)象具有相同的引用,才能被認(rèn)為是相同的鍵。

peopleByManager.get(ceo);
// => [{ name: "Alice", age: 28, reportsTo: ceo }, { name: "Eve", age: 28, reportsTo: ceo }]
peopleByManager.get({ name: "Jamie", age: 40, reportsTo: null });
// => undefined

在上面的例子中,如果嘗試使用與ceo對(duì)象類似的對(duì)象作為鍵去訪問Map中的項(xiàng),由于這個(gè)對(duì)象與之前存儲(chǔ)在Map中的ceo對(duì)象不是同一個(gè)對(duì)象,所以無法檢索到對(duì)應(yīng)的值。

瀏覽器支持

這兩個(gè)groupBy方法是 proposal-array-grouping 提案提出的,該提案目前處于第3階段,預(yù)計(jì)會(huì)在 2024 年成為正式標(biāo)準(zhǔn)。

9 月 12 日,Chrome 117發(fā)布,該版本支持了這兩個(gè)方法。Firefox Nightly 在一個(gè)標(biāo)志后已經(jīng)實(shí)現(xiàn)了這兩個(gè)方法。Safari已經(jīng)以不同的名稱實(shí)現(xiàn)了這些方法。由于這些方法在 Chrome 中可用,這意味著它們已經(jīng)在V8中被實(shí)現(xiàn),所以下一次V8更新時(shí)它們將在Node中可用。

為什么要使用靜態(tài)方法?

你可能會(huì)想,為什么這個(gè)功能被實(shí)現(xiàn)為Object.groupBy而不是Array.prototype.groupBy。根據(jù)提案,有一個(gè)庫(kù)曾經(jīng)用不兼容的groupBy方法對(duì)Array.prototype進(jìn)行了修改。在考慮為Web新增API時(shí),向后兼容性非常重要。幾年前,在嘗試實(shí)現(xiàn)Array.prototype.flatten時(shí)就出現(xiàn)了一個(gè)稱為SmooshGate的事件。

使用靜態(tài)方法實(shí)際上對(duì)未來的可擴(kuò)展性更好。當(dāng)Records和Tuples提案實(shí)現(xiàn)時(shí),可以添加一個(gè)Record.groupBy方法,用于將數(shù)組分組為不可變記錄。

簡(jiǎn)而言之,使用靜態(tài)方法可以更好地保持向后兼容性,并提供更好的擴(kuò)展性,以便在未來添加更多功能和數(shù)據(jù)結(jié)構(gòu)。

JavaScript 正在填補(bǔ)這些空白,并使我們的開發(fā)更簡(jiǎn)單。目前,lodash.groupBy每周的 npm 下載量在 150 萬至 200 萬次之間,當(dāng)所有瀏覽器都支持該方法之后,就不再需要引入lodash.groupBy 庫(kù)了!

責(zé)任編輯:姜華 來源: 前端充電寶
相關(guān)推薦

2023-11-03 07:21:40

Javascript數(shù)組分組

2025-07-29 00:00:00

2023-08-29 09:43:21

Node.js.env

2025-11-07 00:00:00

2015-12-15 10:32:44

chromecss開發(fā)

2020-03-02 15:17:37

云原生CNCF容器

2016-12-21 09:35:55

JavaScript原生數(shù)組函數(shù)

2014-01-22 09:46:42

JavaScript數(shù)組

2023-07-24 09:11:43

CSS滾動(dòng)驅(qū)動(dòng)動(dòng)畫

2022-07-04 09:21:16

GNOME Web瀏覽器

2020-05-08 08:01:11

多線程Redis處理

2024-01-08 09:28:20

2023-05-29 08:38:56

popover控制懸浮層

2025-01-20 00:00:00

Java語言Record

2023-02-13 09:31:07

CSS前端

2023-04-10 09:18:42

CSS前端

2023-11-23 11:37:13

JavaScript數(shù)組

2023-10-31 07:40:15

EslintJSHint

2024-07-08 00:00:07

點(diǎn)贊
收藏

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

欧美亚洲激情在线| 欧美一级理论性理论a| 久久精品中文字幕一区二区三区 | 国产日韩三区| 久久久久亚洲视频| 最新国产精品| 亚洲剧情一区二区| 亚洲高清视频免费| 国模精品视频| 日韩一区欧美小说| 国产亚洲一区二区三区在线播放| 久草免费新视频| 亚洲午夜久久| 日韩欧美国产一二三区| 蜜桃视频一区二区在线观看| 日韩中文字幕影院| 美女性感视频久久| 性色av一区二区三区红粉影视| 久久久久久久穴| 福利一区二区| 亚洲三级视频在线观看| 麻豆91蜜桃| 国产手机视频在线| 秋霞成人午夜伦在线观看| 久久久久久久久久久久av| 日本一二三不卡视频| 美国成人xxx| 色猫猫国产区一区二在线视频| 欧美激情一区二区三区在线视频 | 国产精品日韩欧美一区二区三区| 久久中文字幕无码| 久久夜色精品国产噜噜av小说| 婷婷成人综合网| 欧洲精品国产| 天堂av资源网| 懂色一区二区三区免费观看| 国产免费一区二区三区在线观看 | 欧美小视频在线观看| 尤物一区二区三区| 国产精品二线| 久久久久成人黄色影片| 久久亚洲综合网| 免费观看国产精品| 国产成人啪午夜精品网站男同| 97精品国产97久久久久久| 中国美女乱淫免费看视频| youjizzjizz亚洲| 欧美一级高清大全免费观看| 蜜臀一区二区三区精品免费视频| 国产精品—色呦呦| 亚洲一线二线三线视频| 色婷婷777777仙踪林| 欧美jizz18hd性欧美| 国产欧美日韩精品在线| 欧美亚洲另类在线一区二区三区| 国产伦精品一区二区三区四区| 黄色亚洲在线| 久久久这里只有精品视频| 91麻豆精品国产91久久综合| 国产va免费精品观看精品视频| 91精品国产综合久久久久久漫画 | 潘金莲一级黄色片| 久久资源中文字幕| 久久视频在线免费观看| 91插插插插插插| 欧美日本免费| 久久久久久久色| 99久久精品久久亚洲精品| 成人精品视频| 亚洲美女在线观看| 久久午夜精品视频| 婷婷中文字幕一区| 欧美俄罗斯乱妇| 日韩av大片在线观看| 久久综合九色| 5566成人精品视频免费| 老熟妇仑乱一区二区av| 日本不卡一区二区三区| 国产欧美va欧美va香蕉在线 | 欧美日韩一区中文字幕| 岛国av在线免费| 日本精品一区二区三区在线观看视频| 在线免费亚洲电影| 黄色小视频免费网站| 久久在线观看| 亚洲黄色有码视频| 中文字幕黄色网址| 午夜国产精品视频免费体验区| 日韩在线免费视频| 久久久久久久久97| 日日夜夜精品视频天天综合网| 97福利一区二区| 中文字幕 国产精品| 国产麻豆精品视频| 久久久久久草| 国产三级在线播放| 高跟丝袜一区二区三区| 日韩中文字幕在线视频观看| 久久精品女人天堂av免费观看| 欧美性色xo影院| 亚洲色图偷拍视频| 四虎精品永久免费| 亚洲精品97久久| 亚洲国产精品一区二区久久hs| 精品视频网站| 国模视频一区二区三区| 97成人在线观看| 91社区在线播放| 免费国产一区| 人人澡人人添人人爽一区二区| 一区二区三区鲁丝不卡| 日本新janpanese乱熟| 欧洲av一区二区| 精品美女在线播放| 青花影视在线观看免费高清| 国产日韩一区二区三区在线播放 | 日本熟妇一区二区| 久久er99热精品一区二区| 精品视频一区二区三区四区| 国产秀色在线www免费观看| 欧美丝袜一区二区三区| 岛国大片在线免费观看| 国产劲爆久久| 久久视频免费观看| 欧美激情一区二区三区免费观看| 免费在线欧美视频| 久久久久久九九| 丰满大乳少妇在线观看网站| 日韩欧美在线一区| 国产精品v日韩精品v在线观看| 在线免费成人| 亚洲欧洲在线播放| 国内精品福利视频| 91亚洲精品一区二区乱码| 国产在线观看欧美| 国语精品视频| 亚洲国产日韩欧美在线动漫| 色婷婷在线视频观看| 男人操女人的视频在线观看欧美| 91亚洲精品在线观看| 91美女视频在线| 亚洲成av人片在线观看无码| 成人做爰69片免费| 女人天堂亚洲aⅴ在线观看| 97人人做人人爱| 国产 欧美 精品| 亚洲一区在线视频| 又大又长粗又爽又黄少妇视频| 九九久久精品| 日韩免费观看av| 国产三级视频在线| 欧美影视一区二区三区| 公肉吊粗大爽色翁浪妇视频| 日韩黄色小视频| 日本一区二区三区在线视频| 成年网站在线视频网站| 欧美色综合天天久久综合精品| 国产精久久久久| 欧美一区二区三区高清视频| 欧美精品videos另类日本| www.日韩一区| 国产精品久久久久国产精品日日| 少妇高潮毛片色欲ava片| 国产主播性色av福利精品一区| 色狠狠av一区二区三区香蕉蜜桃| 国产在线免费视频| 99久精品国产| 国产欧美久久久久| 99久久999| 亚洲一区二区久久久| 午夜视频网站在线观看| 国产精品久久久久aaaa樱花 | 亚洲xxxx3d| 国产在线xxx| 欧美一区午夜精品| 国产精品日日夜夜| 久久久国产精华| 91视频这里只有精品| 亚洲视频中文| 欧美日韩一区在线视频| 欧美亚洲福利| 欧美精品久久久久久久久| 欧美精品少妇| 56国语精品自产拍在线观看| 久久视频一区二区三区| 国产精品12区| 久久免费视频3| 天天揉久久久久亚洲精品| 国产精品久久7| 精品视频一区二区三区四区五区| 国产一区二区三区精品久久久 | 成人乱色短篇合集| 韩国日本一区| 精品久久久久久最新网址| www.毛片.com| 亚洲手机成人高清视频| 一本色道综合久久欧美日韩精品 | 久久精品在线视频| 手机在线观看毛片| 欧美性猛交xxxx乱大交3| 中文字幕av网址| 国产成人aaa| 性欧美极品xxxx欧美一区二区| 日韩在线视频精品| 国产在线资源一区| 电影中文字幕一区二区| 55夜色66夜色国产精品视频| 3d玉蒲团在线观看| 中文精品99久久国产香蕉| 手机在线观看免费av| 5566中文字幕一区二区电影| 久久久久亚洲av片无码下载蜜桃| 高清不卡一区二区| 99热一区二区| 日韩精品一二三区| 日本十八禁视频无遮挡| 欧美影视一区| 在线天堂一区av电影| 欧美日韩123| 精品一区久久久| 伊色综合久久之综合久久| 国产精品一区二区性色av | 久久精品日韩一区二区三区| 香蕉网在线视频| 老司机免费视频一区二区三区| 麻豆视频传媒入口| 日韩精品欧美| 国产精品theporn88| **精品中文字幕一区二区三区| 欧美丰满老妇厨房牲生活 | 亚洲第一中文字幕| 日韩在线播放中文字幕| 性感美女极品91精品| 国产精品.www| 午夜亚洲福利老司机| 国产亚洲色婷婷久久99精品| 亚洲欧美偷拍另类a∨色屁股| 国产真实乱人偷精品| 处破女av一区二区| 婷婷六月天在线| 日日夜夜免费精品| 成人3d动漫一区二区三区| 久久久久国内| 国产精品一区二区羞羞答答| 久久成人在线| 青青在线视频免费| 日韩经典一区二区| 性生交免费视频| 毛片一区二区三区| 亚洲怡红院在线| 国产一区免费电影| 日韩av播放器| 美腿丝袜亚洲一区| 国产超级av在线| 美女久久网站| 女性隐私黄www网站视频| 久久久久国产精品一区二区| 国产视频在线视频| 免费成人你懂的| 国产成人无码一二三区视频| 欧美激情1区2区| 亚洲高清精品中出| 天堂美国久久| 91免费版看片| 国产情侣一区| 亚洲天堂网一区| 久久性色av| 91丨九色丨蝌蚪| 福利一区二区在线观看| 疯狂揉花蒂控制高潮h| 久久精品亚洲麻豆av一区二区 | 91精品国产91久久久久麻豆 主演| 成人av二区| 在线观看成人免费| 亚洲激情社区| 日本激情视频在线| 国产乱人伦偷精品视频不卡| 91国内在线播放| 国产.精品.日韩.另类.中文.在线.播放| 污污网站免费观看| 国产激情精品久久久第一区二区 | 成人免费视频播放| 樱花草www在线| 久色婷婷小香蕉久久| 亚洲午夜精品久久久久久性色| 日本一区网站| 精品视频在线观看免费观看| 国模精品一区二区三区| 国产一区二区欧美| 波多野结衣与黑人| 日韩av不卡在线观看| 久久久久久久久久久福利| 麻豆久久一区二区| 国产精品福利导航| 成人欧美一区二区三区白人| 久久久久亚洲AV成人无在 | 中国特级黄色片| 久久精品欧美日韩| 久久精品免费在线| 欧美久久一区二区| 免费福利在线视频| 欧美猛交ⅹxxx乱大交视频| 欧美大片免费观看网址| 亚洲一区二区久久久久久久| 啪啪激情综合网| 日本精品福利视频| 免费观看久久久4p| 亚洲女人在线观看| 国产亚洲精品福利| 久久精品美女视频| 91精品国产色综合久久不卡蜜臀| 国产高清视频免费观看| 一本色道久久综合狠狠躁篇的优点| 91视频在线观看| 欧美一级片久久久久久久| 亚洲不卡在线| 椎名由奈jux491在线播放 | 久久麻豆视频| 麻豆精品蜜桃一区二区三区| 国产真实久久| 樱花草www在线| 亚洲欧洲日韩综合一区二区| 亚洲天堂视频在线播放| 亚洲欧美日韩国产成人| 国内激情视频在线观看| 国产传媒一区| 尤物网精品视频| 亚洲午夜精品在线观看| 综合久久久久久| 欧美日韩精品区| 欧美精品一区二区三区在线| 最新国产露脸在线观看| 成人亚洲激情网| 亚洲a级精品| 欧美一级在线看| 99久久久免费精品国产一区二区| 天天摸日日摸狠狠添| 日本道免费精品一区二区三区| 国产免费一区二区三区最新不卡| 亚洲黄色av女优在线观看| 超黄网站在线观看| 成人三级在线| 日韩视频免费| 亚洲欧美色图视频| 色欧美片视频在线观看在线视频| 国产激情久久久久久熟女老人av| 日韩av网站电影| 日本乱码一区二区三区不卡| 久久99精品久久久久久秒播放器 | 97干在线视频| 成人成人成人在线视频| 国产对白videos麻豆高潮| 精品国产乱码久久| 欧美aa在线观看| 欧美日韩一区二区视频在线观看 | 国内精品久久久久伊人av| 国产成人精品福利| 久久久精品在线视频| 成人免费黄色大片| 黑人一级大毛片| 亚洲香蕉av在线一区二区三区| 韩国成人二区| 日韩高清av电影| 久久er99热精品一区二区| 黄色一级视频免费观看| 亚洲国产欧美自拍| 亚洲一区二区三区四区| 亚洲一区精彩视频| 国产盗摄一区二区三区| 二区视频在线观看| 中文字幕亚洲一区二区三区五十路| 电影一区二区三区| 一本色道婷婷久久欧美| 国产成人av资源| 久久婷婷综合国产| 国产午夜精品麻豆| 国产成年精品| 日本福利视频在线| 亚洲国产成人自拍| jizz国产在线| 亚洲一区二区精品| 香蕉免费一区二区三区在线观看| 最新欧美日韩亚洲| 成人av网站免费| 伊人网中文字幕| 欧美激情一区二区三区在线视频观看| 免费观看在线一区二区三区| 加勒比成人在线| 国产女人aaa级久久久级 | 日本免费在线观看| 国内精品久久国产| 久久99精品一区二区三区| 国产成人啪精品午夜在线观看| 欧美精品一区二区三区一线天视频| 亚洲按摩av| 色综合视频二区偷拍在线| 国产成人亚洲综合色影视| 久久黄色免费视频| 中文字幕欧美视频在线| 国产精品自在线拍|