如何比较两个对象数组并删除javascript中的重复项

问题描述

所以我有以下问题。我有两个对象数组。 Array1 包含许多对象,Array2 包含这些对象的一部分:

array1: [{"first_name": "Wanda","id": 27,"last_name": "Walhai"},{"first_name": "Victoria","id": 26,"last_name": "Viperfisch"}]

array2: [{"first_name": "Victoria","last_name": "Viperfisch"}]

我想要做的是删除 array1 中 array2 也包含的所有对象(重复项)。所以新的 array1 应该是这样的:

array1: [{"first_name": "Wanda","last_name": "Walhai"}]

谁能帮我用javascript实现这个?非常感谢。

解决方法

您可以对所有标识符使用 Set,并使用它过滤掉显示在另一个数组中的 id

function filterById(mainArr,filterArr){
     let idSet = new Set(filterArr.map(obj => obj.id));
     return mainArr.filter(obj => !idSet.has(obj.id));
}

这将删除 mainArr 中显示在 id 中的具有特定 filterArr 的所有对象。

示例:

let arr = [{
    "first_name": "Wanda","id": 27,"last_name": "Walhai"
  },{
    "first_name": "Victoria","id": 26,"last_name": "Viperfisch"
  }
]

let filterArr = [{
  "first_name": "Victoria","last_name": "Viperfisch"
}]

function filterById(mainArr,filterArr){
     let idSet = new Set(filterArr.map(obj => obj.id));
     return mainArr.filter(obj => !idSet.has(obj.id));
}

console.log(filterById(arr,filterArr));