JS对数据进行分组

被分组数据类型:包含n多个对象的数据

代码示例:

let data = [
    { key: 'xxx', name: 'yiyi', age: 12, money: 10 },
    { key: 'sss', name: 'iii', age: 13, money: 100 },
    { key: 'ddd', name: 'ooo', age: 13, money: 50 },
    { key: 'sss', name: 'mmm', age: 50, money: 90 },
    { key: 'ddd', name: '888', age: 13, money: 88 },
    { key: 'aaa', name: 'qqq', age: 30, money: 78 },
    { key: 'aaa', name: 'qqq', age: 13, money: 32 },
    { key: 'xxx', name: 'heh', age: 13, money: 95 },
    { key: 'sss', name: 'rtt', age: 15, money: 456 },
    { key: 'xxx', name: 'opp', age: 15, money: 91 },
    { key: 'ddd', name: 'gun', age: 19, money: 66 },
];

//data是要被分组的数据[],key是分组依据的关键字
let getGroup=(data,key)=>{
    let groups={};
    data.forEach(c=>{
        let value=c[key];
        groups[value]=groups[value]||[];
        groups[value].push(c);
    });
    return groups;
}

console.log(getGroup(data,'key'))

调用这个getGroup方法得到的结果就是

{
    aaa:[
        {key: "aaa", name: "qqq", age: 30, money: 78},
        {key: "aaa", name: "qqq", age: 13, money: 32}
    ],
    ddd:[
        {key: "ddd", name: "ooo", age: 13, money: 50},
        {key: "ddd", name: "888", age: 13, money: 88},
        {key: "ddd", name: "gun", age: 19, money: 66}
    ],
    sss:[
        {key: "sss", name: "iii", age: 13, money: 100},
        {key: "sss", name: "mmm", age: 50, money: 90},
        {key: "sss", name: "rtt", age: 15, money: 456}
    ],
    xxx:[
        {key: "xxx", name: "yiyi", age: 12, money: 10}
        {key: "xxx", name: "heh", age: 13, money: 95}
        {key: "xxx", name: "opp", age: 15, money: 91}
    ]
}

这样同一组数据就在一个对象属性里面了,可以愉快的开始使用分组后的数据了

  • 9
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值