js数组对象去重
时间: 2023-06-22 15:29:45 浏览: 100
可以使用 ES6 的 Set 数据结构来实现数组对象去重,具体代码如下:
```
let arr = [{id: 1, name: 'Alice'}, {id: 2, name: 'Bob'}, {id: 1, name: 'Alice'}];
let set = new Set(arr.map(JSON.stringify));
let uniqueArr = Array.from(set).map(JSON.parse);
console.log(uniqueArr);
```
首先将数组对象转换为字符串形式,然后使用 Set 数据结构去重,最后再将去重后的字符串数组转换为原始的对象数组即可。
相关问题
js数组对象去重es6方法
在ES6中,可以使用Set数据结构来实现数组对象的去重。Set是一种集合数据结构,它只能存储唯一值,可以轻松去除重复项。下面是一种常见的方法:
```javascript
const array = [
{ id: 1, name: 'John' },
{ id: 2, name: 'Jane' },
{ id: 1, name: 'John' },
{ id: 3, name: 'Bob' }
];
const uniqueArray = Array.from(new Set(array.map(JSON.stringify)), JSON.parse);
```
上述代码中,我们首先使用`map`方法将数组中的对象转换为字符串,然后将这些字符串作为元素创建一个新的Set对象。这样,Set会自动去除重复项。最后,我们通过`Array.from`方法将Set对象转换回数组,并使用`JSON.parse`将字符串转换回对象。
现在,`uniqueArray`就是去重后的数组对象。
请注意,这种方法可能会导致对象顺序发生变化,因为Set对象不保持原始顺序。如果需要保持原始顺序,可以使用其他方法来实现去重,例如遍历数组对象并手动比较属性值。
js数组对象去重的方法
JavaScript中数组对象去重的方法有很多种,下面列举几种常见的方法:
1. 使用Set:使用Set数据结构可以快速实现数组对象的去重。通过将数组对象转化为Set,再将Set转化回数组即可实现去重。
```javascript
const arr = [{id: 1}, {id: 2}, {id: 1}, {id: 3}];
const uniqueArr = Array.from(new Set(arr.map(JSON.stringify))).map(JSON.parse);
console.log(uniqueArr);
```
2. 使用reduce方法:利用reduce方法遍历数组对象,通过判断对象在结果数组中是否已存在来进行去重。
```javascript
const arr = [{id: 1}, {id: 2}, {id: 1}, {id: 3}];
const uniqueArr = arr.reduce((result, current) => {
const isExist = result.some(item => item.id === current.id);
if (!isExist) {
result.push(current);
}
return result;
}, []);
console.log(uniqueArr);
```
3. 使用filter方法:利用filter方法和indexOf来判断对象在数组中的索引位置,从而进行去重。
```javascript
const arr = [{id: 1}, {id: 2}, {id: 1}, {id: 3}];
const uniqueArr = arr.filter((item, index, self) => {
return index === self.findIndex(obj => obj.id === item.id);
});
console.log(uniqueArr);
```
以上是一些常见的数组对象去重方法,根据具体业务场景选择适合的方法即可。
阅读全文