数组去重,数组中对象去重,根据数组中对象的某个属性去重

数组去重
一、普通数组去重:三种方法可实现:① new Set 或 ② fileter + indexOf 或 ③ reduce
// 普通数组重复
let arr = [1,1,3,2,2,4,5,6,6,1,7];
  1. new Set(arr);
  2. arr.filter((item,index) => arr.indexOf(item) === index);
  3. arr.reduce((unique,item)=> unique.includes(item) ? unique : [...unique,item],[]);

在这里插入图片描述
在这里插入图片描述

补充: 在简单数组中,找出重复的数据项,使用 indexOflastIndexOf
const arr = [1,1,3,2,2,4,5,6,6,1,7];
const repeatList = arr.filter((item, i) => arr.indexOf(item) !== arr.lastIndexOf(item) && arr.indexOf(item) === i);
console.log(repeatList); // [1,2,6];
二、对象数组去重:ES6的set数据结构去除数组对象中的重复对象 -(完全相同的对象)

思路:①序列化对象为字符串,然后②使用new Set结构去重,最后③再反序列化为对象

// 包含:完全相同的对象
let arr = [
   { name: '张三',  age: 18 },
   { name: '张三',  age: 18 },
   { name: '李四',  age: 20 }
 ];

let noRepeat = [...new Set(arr.map(item => JSON.stringify(item)))];
let newArr = noRepeat.map(item=> JSON.parse(item));
console.log(newArr);

在这里插入图片描述

三、对象数组去重:reduce去除数组对象中的某个重复属性的对象 -(某一属性相同的不同对象)

步骤:① 定义按照过滤的对象的属性名称;② 使用 reduce + some 数组属性对象 去重

// 包含:某一属性相同的不同对象
const arr = [
   { id:1, name:'张三' },
   { id:1, name:'李四' },
   { id:2, name:'张三' },
];

const id = 'id'; // 1、定义按照过滤的对象的属性名称
const newArr = arr.reduce((all,next)=>all.some((item)=>item[id]==next[id])?all:[...all,next],[]); // 2、数组属性对象 去重
console.log(newArr);

在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值