博客
关于我
js:可能是最全的js数组去重方法
阅读量:269 次
发布时间:2019-03-01

本文共 2072 字,大约阅读时间需要 6 分钟。

不考虑引用数据类型

1、利用indexOf去重

function unique(arr) {       if (!Array.isArray(arr)) {           console.log('type error!')        return    }    var array = [];    for (var i = 0; i < arr.length; i++) {           if (array.indexOf(arr[i]) === -1) {               array.push(arr[i])        }    }    return array;}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{   },{   }];console.log(unique(arr))// [1, "true", true, 15, false, undefined, null, NaN, NaN, "NaN", 0, "a", {…}, {…}]  //NaN、{}没有去重

2、es6 Set

方法1:Array.from(new Set(arr))方法2:[...(new Set(arr))]

3、排序后相邻去除法

function unique(arr) {       if (!Array.isArray(arr)) {           console.log('type error!')        return;    }    arr = arr.sort()    var arrry= [arr[0]];    for (var i = 1; i < arr.length; i++) {           if (arr[i] !== arr[i-1]) {               arrry.push(arr[i]);        }    }    return arrry;}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{   },{   }];console.log(unique(arr))// [0, 1, 15, "NaN", NaN, NaN, {…}, {…}, "a", false, null, true, "true", undefined]      //NaN、{}没有去重

4、利用filter

function unique(arr) {     return arr.filter(function(item, index, arr) {       //当前元素,在原始数组中的第一个索引==当前索引值,否则返回当前元素    return arr.indexOf(item, 0) === index;  });}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{   },{   }];console.log(unique(arr))//[1, "true", true, 15, false, undefined, null, "NaN", 0, "a", {…}, {…}]

考虑引用数据类型

1、利用hasOwnProperty

function unique(arr) {       var obj = {   };    return arr.filter(function(item, index, arr){           return obj.hasOwnProperty(typeof item + item) ? false : (obj[typeof item + item] = true)    })}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{   },{   }];console.log(unique(arr))//[1, "true", true, 15, false, undefined, null, NaN, "NaN", 0, "a", {…}]   //所有的都去重了

转载地址:http://wwvo.baihongyu.com/

你可能感兴趣的文章
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>
mysql innodb通过使用mvcc来实现可重复读
查看>>
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
Mysql join原理
查看>>
mysql order by多个字段排序
查看>>
MySQL Order By实现原理分析和Filesort优化
查看>>
mysql problems
查看>>
mysql replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
mysql union orderby 无效
查看>>
mysql where中如何判断不为空
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>