js实现groupby

初始结果是一个数组,最终得到一个对象。

javascript 复制代码
let arr = [{
   sex: 'male',
   name: 'xiaomi'
}, {
   sex: 'male',
   name: 'lisi'
}, {
   sex: 'female',
   name: 'zhangsan'
}]

最终得到:

代码:

javascript 复制代码
const groupBy = (list, key) => {
   const obj = {};
   list.map(item => {
       if (!obj[item[key]]) { //如果不存在这个属性
           obj[item[key]] = [];
       }
       obj[item[key]].push(item);
   });
   return obj;
}

简写:

javascript 复制代码
const group_signal = (data, key) => {
   return data.reduce(function(prev, cur) {
       (prev[cur[key]] = prev[cur[key]] || []).push(cur);
       return prev;
   }, {});
};
相关推荐
用户14536981458781 分钟前
VersionCheck.js - 让前端版本更新变得简单优雅
前端·javascript
米饭同学i2 分钟前
微信小程序实现随机撒花效果
前端
Arthur14726122865472 分钟前
模块化和组件化的区别
前端
codingWhat5 分钟前
整理「祖传」代码,就是在开发脚手架?
前端·javascript·node.js
码路飞13 分钟前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python
臣妾没空15 分钟前
里程碑5:完成框架npm包抽象封装并发布
前端·npm
Lee川15 分钟前
优雅进化的JavaScript:从ES6+新特性看现代前端开发范式
javascript·面试
Wect16 分钟前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
cxxcode20 分钟前
搞懂 JS 异步的底层真相:从 V8 源码看微任务与宏任务
前端
欧阳的棉花糖20 分钟前
React 小误区:派生值 vs useEffect
前端