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}
    ]
}

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

在 Element Plus 的 Vue3 中,对数据进行分组通常可以使用 `chunk` 或者 `groupBy` 策略,特别是当你需要按照某个字段将数据划分成多个小组的时候。以下是两种常见的做法: 1. **基于 `v-for` 和自定义 key**: ```html <el-table :data="groupedData"> <el-table-column prop="groupName" label="分组"></el-table-column> <template v-for="(itemGroup, index) in chunks(items, groupKey)"> <el-row :key="index"> <el-col :span="4">{{ itemGroup[0].yourField }}</el-col> <!-- 使用每个分组的第一个元素作为展示 --> <el-col :span="16">{{ itemGroup }}</el-col> <!-- 展示整个分组 --> </el-row> </template> </el-table> // JavaScript 部分 computed: { groupedData() { const groupKey = 'yourGroupingField'; // 指定按哪个字段分组 return this.items.reduce((acc, curr) => { acc[curr[groupKey]] ||= []; acc[curr[groupKey]].push(curr); return acc; }, {}); }, chunks(array, size) { return array.reduce((chunks, current, index) => { if (index % size === 0 && index !== 0) { chunks.push([]); } chunks[chunks.length - 1].push(current); return chunks; }, []); } } ``` 2. **使用内置的 `groupBy` 函数(如果使用了 lodash 或者其他库)**: 如果你已经在项目中引入了lodash或其他类似库,你可以利用它们的 `groupBy` 方法简化分组过程: ```javascript import _ from 'lodash'; computed: { groupedData() { const groupKey = 'yourGroupingField'; return _.groupBy(this.items, groupKey); } } ``` 然后直接在模板上遍历这个 `groupedData`。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值