成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

使用 JavaScript 進(jìn)行數(shù)據(jù)分組最優(yōu)雅的方式

開發(fā) 前端
對(duì)數(shù)據(jù)進(jìn)行分組,是我們?cè)陂_發(fā)中經(jīng)常會(huì)遇到的需求,使用 JavaScript 進(jìn)行數(shù)據(jù)分組的方式也有很多種,但是由于沒有原生方法的支持,我們自己實(shí)現(xiàn)的數(shù)據(jù)分組函數(shù)通常都比較冗長(zhǎng)而且難以理解。

大家好,我是 ConardLi ,今天我們一起來(lái)看一個(gè)數(shù)據(jù)分組的小技巧。

對(duì)數(shù)據(jù)進(jìn)行分組,是我們?cè)陂_發(fā)中經(jīng)常會(huì)遇到的需求,使用 JavaScript 進(jìn)行數(shù)據(jù)分組的方式也有很多種,但是由于沒有原生方法的支持,我們自己實(shí)現(xiàn)的數(shù)據(jù)分組函數(shù)通常都比較冗長(zhǎng)而且難以理解。

不過,告訴大家一個(gè)好消息,一個(gè)專門用來(lái)做數(shù)據(jù)分組的提案 Array.prototype.groupBy 已經(jīng)到達(dá) Stage 3 啦!

在看這個(gè)提案,之前,我們先來(lái)回顧下我們以前在 JavaScript 里是怎么分組的。

以前的方式

假設(shè)我們有下面一組數(shù)據(jù):

  1. const items = [ 
  2.   { 
  3.     type: 'clothes', 
  4.     value: '👔', 
  5.   }, 
  6.   { 
  7.     type: 'clothes', 
  8.     value: '👕', 
  9.   }, 
  10.   { 
  11.     type: 'clothes', 
  12.     value: '👗', 
  13.   }, 
  14.   { 
  15.     type: 'animal', 
  16.     value: '🐷', 
  17.   }, 
  18.   { 
  19.     type: 'animal', 
  20.     value: '🐸', 
  21.   }, 
  22.   { 
  23.     type: 'animal', 
  24.     value: '🐒', 
  25.   }, 
  26. ]; 

我們希望按照 type 分組成下面的格式:

  1. const items = { 
  2.   clothes: [ 
  3.     { 
  4.       type: 'clothes', 
  5.       value: '👔', 
  6.     }, 
  7.     { 
  8.       type: 'clothes', 
  9.       value: '👕', 
  10.     }, 
  11.     { 
  12.       type: 'clothes', 
  13.       value: '👗', 
  14.     }, 
  15.   ], 
  16.   animal: [ 
  17.     { 
  18.       type: 'animal', 
  19.       value: '🐷', 
  20.     }, 
  21.     { 
  22.       type: 'animal', 
  23.       value: '🐸', 
  24.     }, 
  25.     { 
  26.       type: 'animal', 
  27.       value: '🐒', 
  28.     }, 
  29.   ], 
  30. }; 

我們可能會(huì)用到下面的寫法:

for 循環(huán)

最直接而且容易理解的方法,就是代碼有點(diǎn)多。

  1. const groupedBy = {}; 
  2.  
  3. for (const item of items) { 
  4.   if (groupedBy[item.type]) { 
  5.     groupedBy[item.type].push(item); 
  6.   } else { 
  7.     groupedBy[item.type] = [item]; 
  8.   } 

reduce

使用 Array.protoype.reduce 雖然語(yǔ)法看起來(lái)簡(jiǎn)單,但是太難讀了。

  1. items.reduce( 
  2.   (acc, item) => ({ 
  3.     ...acc, 
  4.     [item.type]: [...(acc[item.type] ?? []), item], 
  5.   }), 
  6.   {}, 
  7. ); 

我們稍微改造的容易理解一點(diǎn),語(yǔ)法就跟上面的 for 循環(huán)差不多了:

  1. items.reduce((acc, item) => { 
  2.   if (acc[item.type]) { 
  3.     acc[item.type].push(item); 
  4.   } else { 
  5.     acc[item.type] = [item]; 
  6.   } 
  7.  
  8.   return acc; 
  9. }, {}); 

filter

使用 Array.prototype.filter,代碼看起來(lái)很容易閱讀,但是性能很差,你需要對(duì)數(shù)組進(jìn)行多次過濾,而且如果 type 屬性值比較多的情況下,還需要做更多的 filter 操作。

  1. const groupedBy = { 
  2.   fruit: items.filter((item) => item.type === 'clothes'), 
  3.   vegetable: items.filter((item) => item.type === 'animal'), 
  4. }; 

其他

如果你既不想用 reduce,還想用到函數(shù)式寫法,你可能會(huì)寫出下面的代碼:

  1. Object.fromEntries( 
  2.   Array.from(new Set(items.map(({ type }) => type))).map((type) => [ 
  3.     type, 
  4.     items.filter((item) => item.type === type), 
  5.   ]), 
  6. ); 

是不是很讓人崩潰 🤯~

Array.prototype.groupBy

好了,如果使用 Array.prototype.groupBy,你只需要下面這一行代碼:

  1. items.groupBy(({ type }) => type); 

groupBy 的回調(diào)中一共有三個(gè)參數(shù):

  • 參數(shù)1:數(shù)組遍歷到的當(dāng)前對(duì)象
  • 參數(shù)2:index 索引
  • 參數(shù)3:原數(shù)組
  1. const array = [1, 2, 3, 4, 5]; 
  2.  
  3. // groupBy groups items by arbitrary key. 
  4. // In this case, we're grouping by even/odd keys 
  5. array.groupBy((num, index, array) => { 
  6.   return num % 2 === 0 ? 'even': 'odd'; 
  7. }); 

另外,你還可以用 groupByToMap,將數(shù)據(jù)分組為一個(gè) Map 對(duì)象。

  1. // groupByToMap returns items in a Map, and is useful for grouping using 
  2. // an object key. 
  3. const odd  = { odd: true }; 
  4. const even = { even: true }; 
  5. array.groupByToMap((num, index, array) => { 
  6.   return num % 2 === 0 ? even: odd; 
  7. }); 
  8.  
  9. // =>  Map { {odd: true}: [1, 3, 5], {even: true}: [2, 4] } 

 

責(zé)任編輯:趙寧寧 來(lái)源: code秘密花園
相關(guān)推薦

2017-03-20 16:30:15

Android退出應(yīng)用優(yōu)雅方式

2025-01-26 00:00:35

2017-10-31 11:55:46

sklearn數(shù)據(jù)挖掘自動(dòng)化

2017-02-16 08:41:09

數(shù)據(jù)Vlookup匹配

2019-09-30 10:12:21

機(jī)器學(xué)習(xí)數(shù)據(jù)映射

2009-09-08 16:50:12

使用LINQ進(jìn)行數(shù)據(jù)轉(zhuǎn)

2022-11-02 14:45:24

Python數(shù)據(jù)分析工具

2009-03-16 10:29:45

數(shù)據(jù)挖掘過濾器Access

2023-08-15 16:20:42

Pandas數(shù)據(jù)分析

2022-03-28 14:08:02

Python數(shù)據(jù)清洗數(shù)據(jù)集

2010-03-29 18:31:09

Nginx配置

2009-07-16 14:46:48

jdbc statem

2022-04-08 11:25:58

數(shù)據(jù)庫(kù)操作AbilityData

2021-07-27 15:40:39

Python數(shù)據(jù)清洗函數(shù)

2023-10-18 18:38:44

數(shù)據(jù)校驗(yàn)業(yè)務(wù)

2011-10-14 14:24:26

Ruby

2021-07-17 22:41:53

Python數(shù)據(jù)技術(shù)

2022-06-02 13:59:57

數(shù)據(jù)遷移數(shù)據(jù)

2022-01-26 09:00:00

數(shù)據(jù)庫(kù)SnowparkSQL

2024-10-28 12:57:36

Pandas數(shù)據(jù)清洗
點(diǎn)贊
收藏

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

主站蜘蛛池模板: 欧美一级一 | 精品国偷自产在线 | 日韩国产一区二区三区 | 亚洲欧美中文字幕 | 国产精品视频久久久久 | 精品乱码一区二区三四区视频 | 亚洲成av人片在线观看无码 | 在线观看av不卡 | 日韩另类视频 | 91视在线国内在线播放酒店 | 日韩欧美中文字幕在线观看 | 国产精品视频免费观看 | 久久人人网| 国内自拍第一页 | 国产99久久精品一区二区永久免费 | www.亚洲精品| 黄片毛片| 国产一二区视频 | 免费精品一区 | 国产成人av一区二区三区 | 天天综合久久 | 久久精品亚洲精品国产欧美 | 日韩精品一区二区三区老鸭窝 | 久久精品国产久精国产 | 亚洲精彩视频 | 精品久久久久一区二区国产 | 91麻豆精品国产91久久久久久 | 日韩成人av在线 | 成人精品鲁一区一区二区 | 日韩高清一区 | 久久久国产亚洲精品 | 台湾佬久久 | 久久er99热精品一区二区 | 在线日韩精品视频 | 欧美又大粗又爽又黄大片视频 | 国产成人精品一区二区三区四区 | 九九热在线视频 | 四虎网站在线观看 | 在线视频一区二区 | 欧美午夜精品久久久久免费视 | 久草成人 |