当前位置:
首页 > 网站开发 > JavaScript教程 >
-
JavaScript实现数组对象去重
有多种实现方式:
一、使用 Set
对象:
1
|
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);
出处:https://www.cnblogs.com/lyso/p/17106852.html
最新更新
go语言写http踩得坑
【Python】爬虫笔记-从PyMySQL到DBUtils
【Python】爬虫笔记-开源代理池haipproxy使用
Python规范:提高可读性
C语言两结构体之间的成员互换
【爬虫实战项目】Python爬取Top100电影榜单
linux(Ubuntu)安装python
anaconda peompt 、labalimg 数据标注
【Python数据分析案例】python数据分析老番
【爬虫+情感判定+Top10高频词+词云图】“
SqlServer服务中利用触发器对指定账户进行
一次SQL调优 聊一聊 SQLSERVER 数据页
聊一聊 SQLSERVER 的行不能跨页
再聊一下那 SQLSERVER 行不能跨页的事
大数据概述
支线第九篇:
数据库的值获取过来转换成Json数组的方法
支线第八篇:数据类型转换
支线第七篇:又是解决报错
支线第六篇:停下脚步,理清思路
原型和原型链的深入浅出
JavaScript实现数组对象去重
关于 NodeJs 处理超长字符串问题的分析
JavaScript中的函数
使用JS的DOM(文档对象模型)获取前端循
JS web sql database 几个功能组合的实现
30个Javascript知识点总结,总有你不会的!
【促进开发】上海道宁与DHTMLX为您提供易
如何手动补充陈年老库(或纯 JS 代码)的
半个前端新手入门Electron的过程