js用一个数组对象对另一个数组对象去重
时间: 2023-08-10 21:58:29 浏览: 51
你可以使用 `Array.filter()` 方法来实现对一个数组对象去重,以下是一个示例代码:
```javascript
let array1 = [
{ id: 1, name: 'John' },
{ id: 2, name: 'Jane' },
{ id: 3, name: 'John' }
];
let array2 = [
{ id: 4, name: 'John' },
{ id: 5, name: 'Jane' },
{ id: 6, name: 'Mary' }
];
let uniqueArray = array1.filter(obj1 => !array2.some(obj2 => obj1.id === obj2.id && obj1.name === obj2.name));
console.log(uniqueArray);
```
在上面的例子中,`array1` 和 `array2` 是两个数组对象,你想要从 `array1` 中去除与 `array2` 中重复的元素。使用 `Array.filter()` 方法对 `array1` 进行筛选,通过使用 `Array.some()` 方法来判断元素是否存在于 `array2` 中。如果元素不存在于 `array2` 中,则保留在 `uniqueArray` 中。
这样,`uniqueArray` 将会是一个仅包含 `array1` 中独有的元素的数组对象。
相关问题
js一个数组对象去重
你可以使用以下几种方法来对一个数组对象进行去重:
1. 使用 Set 数据结构:将数组转换为 Set,然后再将 Set 转换回数组。由于 Set 的特性是不允许重复值,所以会自动重。
```javascript
const array = [{id: 1}, {id: 2 {id: 1}];
const uniqueArray = Array.from(new Set(array.map(JSON.stringify)),.parse);
console.log(uniqueArray);
```
2. 使用 reduce 方法:使用 reduce 方法遍历数组,将每个对象的某个属性作为键,存储到一个空对象中,最后获取对象的值转换为数组。
```javascript
const array = [{id: 1}, {id: 2}, {id: 1}];
const uniqueArray = Object.values(array.reduce((acc, obj) => {
acc[obj.id] = obj;
return acc;
}, {}));
console.log(uniqueArray);
```
3. 使用 filter 方法:使用 filter 方法遍历数组,通过判断某个属性在新数组中是否已存在来进行去重。
```javascript
const array = [{id: 1}, {id: 2}, {id: 1}];
const uniqueArray = array.filter((obj, index, self) =>
index === self.findIndex((o) => o.id === obj.id)
);
console.log(uniqueArray);
```
以上是几种常见的数组对象去重方法,你可以根据具体的需求选择适合的方法。
用js写一个数组对象去重方法
以下是一种常见的去重方法:
```javascript
function unique(arr) {
var obj = {};
var result = [];
for (var i = 0; i < arr.length; i++) {
if (!obj[arr[i]]) {
obj[arr[i]] = true;
result.push(arr[i]);
}
}
return result;
}
```
使用方式:
```javascript
var arr = [1, 1, 2, 3, 3, 3, 4, 5, 5];
var result = unique(arr);
console.log(result); // [1, 2, 3, 4, 5]
```
该方法使用一个对象来记录数组中出现过的元素,遇到重复元素就跳过,最后返回去重后的结果数组。