js两个对象数组合并。并且去掉里边某个属性相同的对象

要合并两个JavaScript对象数组并去除其中某个属性相同的对象,您可以使用concat()方法将两个数组合并,然后使用reduce()方法进行筛选。

以下是一个示例代码,演示了如何合并两个对象数组并去除其中某个属性相同的对象

const array1 = [{ id: 1, name: 'John' }, { id: 2, name: 'Alice' }];
const array2 = [{ id: 2, name: 'Bob' }, { id: 3, name: 'Jane' }];

const mergedArray = array1.concat(array2).reduce((acc, obj) => {
  const found = acc.find(item => item.id === obj.id);
  if (!found) {
    acc.push(obj);
  }
  return acc;
}, []);

console.log(mergedArray);

在上述示例中,我们首先使用concat()方法将两个对象数组array1array2合并成一个新数组。然后,我们使用reduce()方法对合并后的数组进行筛选。

reduce()方法的回调函数中,我们使用find()方法来查找已经存在于累加器数组acc中的对象是否具有相同的id属性。如果没有找到相同的id属性,我们将当前对象obj添加到累加器数组中。

最后,我们将去重后的合并数组打印到控制台,即可看到结果。

请注意,这种方法会根据指定的属性进行去重操作,但是它只会保留第一个出现的对象,后续出现的对象将被忽略。如果您需要保留最后出现的对象或者其他去重规则,请根据具体需求进行相应的调整。

  • 7
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值