JavaScript实现数组对象去重的多种方法
JavaScript实现数组对象去重的多种方法
有多种实现方式:
一、使用 Set 对象:
Array.from(new Set(array))
该方法会先创建一个 Set
对象,然后再使用 Array.from
方法将 Set
对象转换为数组,因为 Set
对象不允许有重复的元素,所以这样可以实现去重的效果。
但是,如果数组中的元素是对象,Set
对象会识别为不同的元素,所以不能直接使用该方法。为了解决这个问题,你可以使用一个映射函数,将数组中的对象映射为一个字符串或数字,然后再使用该方法。
以下是一个具体的例子:
const arr = [ { id: 1, name: 'A' }, { id: 2, name: 'B' }, { id: 1, name: 'A' }, { id: 3, name: 'C' } ]; const result = Array.from(new Set(arr.map(item => JSON.stringify(item)))).map(item => JSON.parse(item)); console.log(result);
二、使用`reduce`方法:
const arr = [ { id: 1, name: 'A' }, { id: 2, name: 'B' }, { id: 1, name: 'A' }, { id: 3, name: 'C' } ]; const result = arr.reduce((pre, cur) => { var exists = pre.find(item => JSON.stringify(item) === JSON.stringify(cur)); if (!exists) { pre.push(cur); } return pre; }, []); console.log(result);
三、使用`filter`方法
const arr = [ { id: 1, name: 'A' }, { id: 2, name: 'B' }, { id: 1, name: 'A' }, { id: 3, name: 'C' } ]; const result =arr.filter((item, index, self) => { return self.findIndex(t => JSON.stringify(t) === JSON.stringify(item)) === index; }); console.log(result);
补充:js数组对象去重
1、使用reduce()方法对象数组去重
通过数组的reduce()方法对数组的对象从左到右进行处理,定义一个空对象obj{};
如果数组当前对象的name不在obj{},就将当前对象的name加入到空对象,并将当前对象push到积累变量total数组里;
如果当前对象的name存在obj{},则跳过push操作。
//reduce第一个参数是遍历需要执行的函数,第二个参数是item的初始值 var arr = [{"id":1,"name":"张三"},{"id":2,"name":"李四"},{"id":3,"name":"王五"},{"id":2,"name":"张三"}]; var obj = {}; arr = arr.reduce(function(item, next) { obj[next.id] ? '' : obj[next.id] = true && item.push(next); return item; }, []); console.log(arr);
2、利用set去重
可以判断多个属性,这里判断了两个条件,(id 和 name)
var arr2 = [{"id":1,"name":"张三"},{"id":2,"name":"李四"},{"id":3,"name":"王五"},{"id":2,"name":"张三"},{'id':4,'name':'李四'}]; function unique(arr){ const res= new Map() return arr.filter((a)=> !res.has(a.id) && res.set(a.id,1) && !res.has(a.name) && res.set(a.name,1)) } //输出结果: unique(arr2) [ { "id": 1, "name": "张三" }, { "id": 2, "name": "李四" }, { "id": 3, "name": "王五" } ]
到此这篇关于JavaScript实现数组对象去重的多种方法的文章就介绍到这了,更多相关js数组对象去重内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
JavaScript具有类似Lambda表达式编程能力的代码(改进版)
在之前的一篇博文中我介绍了一种方法可以让JavaScript具有一种近似于Lambda表达式的编程能力——但是它有一些缺点,其中妨碍它的使用的最主要的一条就是多了一层括号,让代码变得难以阅读。2010-09-09js获取元素到文档区域document的(横向、纵向)坐标的两种方法
获取页面中元素到文档区域document的横向、纵向坐标,在js控制元素运动的过程中,对于页面元素坐标位置的获取是经常用到的,这里主要总结下两种方法2013-05-05
最新评论