问答

es6根据数组对象里的指定字段累加并去重

作者:admin 2021-04-07 我要评论

例如: const arr = [ {id:1,typeId:1,num:2}, {id:2,typeId:1,num:5}, {id:3,typeId:2,num:2}, {id:4,typeId:2,num:1}, {id:5,typeId:3,num:2}, {id:6,typeId:3...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

例如:

const arr = [
    {id:1,typeId:1,num:2},
    {id:2,typeId:1,num:5},
    {id:3,typeId:2,num:2},
    {id:4,typeId:2,num:1},
    {id:5,typeId:3,num:2},
    {id:6,typeId:3,num:2},
    {id:7,typeId:3,num:2},
];

如果只是去重使用map()和filter()方法就行

const res = new Map();
arr.filter((item)=>{
    !res.has(item.typeId) && res.set(item.typeId,1)
});

现在我想要的是能够去重,但相同的typeId的num要累加
最后的结果希望是这样的:

const arr = [
    {id:1,typeId:1,num:7},
    {id:3,typeId:2,num:3},
    {id:5,typeId:3,num:6},
];

不知道有什么办法能解决

###
arr.reduce((list, item)=>{
    if(res.has(item.typeId)){
        res.get(item.typeId).num += item.num
    }else{
        let o = {...item}
        list.push(o)
        res.set(item.typeId, o)
    }
    
    return list
}, []);
###
Object.values([
    {id:1,typeId:1,num:2},
    {id:2,typeId:1,num:5},
    {id:3,typeId:2,num:2},
    {id:4,typeId:2,num:1},
    {id:5,typeId:3,num:2},
    {id:6,typeId:3,num:2},
    {id:7,typeId:3,num:2},
].reduce((res,v)=>{
    if(res[v.typeId]) res[v.typeId].num += v.num;
    else res[v.typeId] = v;
    return res;
}, {}))
###

const arr = [

{id: 1, typeId: 1, num: 2},
{id: 2, typeId: 1, num: 5},
{id: 3, typeId: 2, num: 2},
{id: 4, typeId: 2, num: 1},
{id: 5, typeId: 3, num: 2},
{id: 6, typeId: 3, num: 2},
{id: 7, typeId: 3, num: 2},

];
const map = new Map();
arr.forEach(item => {

const value = map.get(item.typeId);
if (value) {
    value.num += item.num;
    map.set(item.typeId, value);
} else {
    map.set(item.typeId, item);
}

});
const result = [...map.values()];
console.log(result);

###
Object.values(arr.reduce((res, item) => {
  res[item.typeId] || (res[item.typeId] = {...item, num: 0})
  res[item.typeId].num += item.num;
  return res;
}, {}));
###

你这个不能称为去重,只能是相同typeId的累加。
理论上新的数组中不该有id属性的。

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • nginx响应速度很慢

    nginx响应速度很慢

  • 点击选中的多选框,会在已选那一栏显示

    点击选中的多选框,会在已选那一栏显示

  • PHP 多态的理解

    PHP 多态的理解

  • 关于C语言中static的问题

    关于C语言中static的问题

腾讯云代理商
海外云服务器