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

這樣同一組數據就在一個對象屬性裏面了,可以愉快的開始使用分組後的數據了

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章