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

2023-12-26 12:44:05

要合并两个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添加到累加器数组中。

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

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

文章来源:https://blog.csdn.net/taoqidexiaojie/article/details/135217280
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。