js之数组去重

要对包含对象的数组进行去重操作,可以使用`filter()`方法和`Set`数据结构。下面是一个示例:

```javascript
// 假设我们有一个包含对象的数组
const products = [
  { id: 1, name: 'apple' },
  { id: 2, name: 'banana' },
  { id: 3, name: 'apple' },
  { id: 4, name: 'orange' },
  { id: 5, name: 'banana' }
];

// 使用filter()方法和Set数据结构进行去重
const uniqueProducts = Array.from(new Set(products.map(JSON.stringify)), JSON.parse);

console.log(uniqueProducts);
```

在上面的示例中,我们首先使用`map()`方法将数组中的每个对象转换成字符串表示形式,通过`JSON.stringify`进行转换。然后,我们使用`Set`数据结构将这些字符串表示形式的对象去重。最后,我们通过`Array.from`和`JSON.parse`将去重后的字符串转换回对象形式,得到去重后的数组`uniqueProducts`。

在示例中,我们对包含有重复对象的`products`数组进行去重操作,最终得到的`uniqueProducts`数组如下所示:

```javascript
[
  { id: 1, name: 'apple' },
  { id: 2, name: 'banana' },
  { id: 4, name: 'orange' }
]
```

注意,这种方法会保留第一次出现的对象,后面出现的相同对象会被过滤掉。如果需要根据对象的某个属性进行去重,可以在`map()`方法中指定该属性。例如,如果要根据`name`属性进行去重,可以将`products.map(JSON.stringify)`改为`products.map(product => JSON.stringify(product.name))`。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值