对象数组根据某一相同项合并其他属性为一个数组

 

对象数组示例:

var objects = [
  {name:'group1', usedCount: 2, color:'red'},
  {name:'group1', usedCount: 1, color:'blue'},
  {name:'group1', usedCount: 1, color:'orange'},
  {name:'group2', usedCount: 2, color:'blue'},
  {name:'group2', usedCount: 2, color:'red'},
  {name:'group3', usedCount: 1, color:'red'},
  {name:'group3', usedCount: 4, color:'red'}
]

分组合并后的结果

[
  {name:'group1', usedCount: 4, color:['red','blue','orange']},
  {name:'group2', usedCount: 4, color:['blue','red']},
  {name:'group3', usedCount: 5, color:['red']}
]

这是根据对象的name进行合并,合并后,usedCount累加,color合并为数组。


方法:

var result= objects.reduce((groups, item)=>{   var groupFound= groups.find(arrItem => item.name === arrItem.name);   if(groupFound) {     groupFound.usedCount += item.usedCount;     if(groupFound.color.indexOf(item.color)  == -1) {  //去重       groupFound.color.push(item.color);     }   } else {     //不要直接在原来的对象修改,新建对象     var newGroup = {         name: item.name,         usedCount: item.usedCount,         color: [item.color]     }     groups.push(newGroup);   }   return groups; },[]); console.log(result);

转载于:https://www.cnblogs.com/xiaomaotao/p/11170177.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值