首页IT科技js如何数组去重(JS实现数组去重的八种方法(实用))

js如何数组去重(JS实现数组去重的八种方法(实用))

时间2025-05-03 03:53:44分类IT科技浏览3646
导读:前言 js数组去重是比较常见的数组操作方式之一,网上有很多关于数组去重的博客文章,方法各式各样,但有些方法实用性很差,很容易造成不必要的麻烦,所以我们需要去其糟粕取其精华,下面我们就整理一些比较实用的数组去重方法。...

前言

js数组去重是比较常见的数组操作方式之一            ,网上有很多关于数组去重的博客文章                ,方法各式各样      ,但有些方法实用性很差         ,很容易造成不必要的麻烦                ,所以我们需要去其糟粕取其精华         ,下面我们就整理一些比较实用的数组去重方法            。

Methods 1:利用双重for循环

思路:定义一个新数组      ,并存放原数组的第一个元素                ,然后将元素组一一和新数组的元素对比           ,若不同则存放在新数组中                。

Methods 2:利用对象

思路:利用对象属性存在的特性   ,如果没有该属性则存入新数组

function unique(arr) { const newArr = [] const obj = {} arr.forEach(item => { if (!obj[item]) { newArr.push(item) obj[item] = true } }) return newArr } console.log(unique([1, 1, 2, 5, 5, 3, 4, 9, 6, 3, 4])) // 结果是[1, 2, 5, 3, 4, 9, 6]

Methods 3:利用数组的indexOf方法

思路:新建一个空数组                 ,遍历需要去重的数组             ,将数组元素存入新数组中,存放前判断数组中是否已经含有当前元素               ,没有则存入      。此方法也无法对NaN去重         。

var arr = [1,9,8,8,7,2,5,3,3,3,2,3,1,4,5,444,55,22]; function unique(arr) { //定义一个新的临时数组 var newArr=[]; //遍历当前数组 for(var i=0;i<arr.length;i++) { //如果当前数组的第i已经保存进了临时数组                ,那么跳过   , //否则把当前项push到临时数组里面 if(newArr.indexOf(arr[i]) === -1) { //indexOf() 判断数组中有没有字符串值            ,如果没有则返回 -1 newArr.push(arr[i]); } } return newArr } var arr2 = unique(arr); console.log(arr2); //[ 1, 9, 8, 7, 2, 5, 3, 4, 444, 55, 22]

Methods 4:利用数组的includes方法

思路:此方法逻辑与indexOf方法去重异曲同工                ,只是用includes方法来判断是否包含重复元素                。

function unique(arr) { var newArr = [] for (var i = 0; i < arr.length; i++) { if (!newArr.includes(arr[i])) { newArr.push(arr[i]) } } return newArr } console.log(unique([1,5,1,5,3,74,32,7,32,6,9,4,7,4])); // 结果是[1, 5, 3, 74, 32, 7, 6, 9, 4]

Methods 5:利用数组的 filter 和 includes方法

同理      ,filter+indexOf也可

function unique(arr) { var newArr = [] newArr = arr.filter(function (item) { return newArr.includes(item) ? : newArr.push(item) }) return newArr } console.log(unique([1,5,1,5,3,74,32,7,32,6,9,4,7,4])); // 结果是[1, 5, 3, 74, 32, 7, 6, 9, 4]

Methods 6:利用数组的 forEach 和 includes方法

function unique(arr) { let newArr = []; arr.forEach(item => { return newArr.includes(item) ? : newArr.push(item); }); return newArr; } console.log(unique([1,1,2,5,6,3,5,5,6,8,9,8])); // 结果是[1, 2, 5, 6, 3, 8, 9]

Methods 7:利用数组的 splice 方法         。

function unique(arr){ for(var i=0;i<arr.length;i++){ for(var j=i+1;j<arr.length;j++){ if(arr[i]==arr[j]){ //如果第一个等于第二个         ,splice方法删除第二个 arr.splice(j,1); j--; } } } return arr; } var arr = [1,1,2,5,6,3,5,5,6,8,9,8]; console.log(unique(arr)) //[ 1, 2, 5, 6, 3, 8, 9 ]

Methods 8:利用Set()+Array.from()

代码最简洁                ,原理:

Set对象:是值的集合         ,你可以按照插入的顺序迭代它的元素      。 Set中的元素只会出现一次      ,即Set中的元素是唯一的                。 Array.from() 方法:对一个类似数组可迭代对象创建一个新的                ,浅拷贝的数组实例           。 function unique(arr){ return Array.from(new Set(arr)) } var arr = [1,1,2,9,6,9,6,3,1,4,5]; console.log(unique(arr)) //[ 1, 2, 9, 6, 3, 4, 5 ]
声明:本站所有文章           ,如无特殊说明或标注   ,均为本站原创发布   。任何个人或组织                 ,在未征得本站同意时             ,禁止复制          、盗用                  、采集      、发布本站内容到任何网站       、书籍等各类媒体平台                 。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理             。

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
如何优化网站标题,提高搜索引擎排名(掌握优化技巧,让你的网站更易被搜索引擎识别) vueconfig.js配置文件host(【前端】Vue+Element UI案例:通用后台管理系统-项目总结)