#LearnedToday:Object.groupBy()

PHPz
发布: 2024-08-26 21:39:08
原创
688 人浏览过

#LearnedToday: Object.groupBy()

? It is finally out! No more need to write ugly code to group an array of objects by a specific value of a field!

Since late 2023, there is an official static method for Object called groupBy() that does it for us!
It accepts an Iterable, such as an Array, and a function, which is executed for each element and must return the "category" of that specific element.
The method returns a new Object where each key is a different category that contains an array of objects belonging to that specific category.

NOTE: The elements in the returned object and the original iterable are the same (not deep copies!). Changing the internal structure of the elements will be reflected in both the original iterable and the returned object.

Example

Let's give a practical example to see how easy it is togroup all the Ninja Turtles characters by age.

The initial Array

const ninjaTurtlesCharacters = [ { age: 16, name: 'Michelangelo' }, { age: 16, name: 'Raffaello' }, { age: 16, name: 'Donatello' }, { age: 16, name: 'Leonardo' }, { age: 91, name: 'Splinter' }, { age: 25, name: 'Casey Jones' }, { age: 25, name: 'April O\'Neil' } ];
登录后复制

The good OLD way (with reduce)

const ninjaTurtlesCharactersByAge = ninjaTurtlesCharacters.reduce( (groupedPeople, item) => ({ ...groupedPeople, [item.age]: groupedPeople[item.age] ? [...groupedPeople[item.age], item] : [item], }), {} );
登录后复制

The MODERN way

const ninjaTurtlesCharactersByAgeNew = Object.groupBy( ninjaTurtlesCharacters, ({ age }) => age );
登录后复制

Tip: use Map.groupBy() if you want to return a Map instead of an Object

The result

{ "16": [ { age: 16, name: 'Michelangelo' }, { age: 16, name: 'Raffaello' }, { age: 16, name: 'Donatello' }, { age: 16, name: 'Leonardo' } ], "25": [ { age: 25, name: 'Casey Jones' }, { age: 25, name: 'April O\'Neil' } ], "91": [ { age: 91, name: 'Splinter' } ] }
登录后复制

Demo

??? As usual, I created a simple Stackblitz prject to play with the code.

? Docs: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/groupBy

ℹ Browser support: https://caniuse.com/mdn-javascript_builtins_object_groupby

以上是#LearnedToday:Object.groupBy()的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!