博客
关于我
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事务及其特性与锁机制
查看>>
mysql事务理解
查看>>
MySQL事务详解结合MVCC机制的理解
查看>>
MySQL事务隔离级别:读未提交、读已提交、可重复读和串行
查看>>
MySQL事务隔离级别:读未提交、读已提交、可重复读和串行
查看>>
webpack css文件处理
查看>>
mysql二进制包安装和遇到的问题
查看>>
MySql二进制日志的应用及恢復
查看>>
mysql互换表中两列数据方法
查看>>
mysql五补充部分:SQL逻辑查询语句执行顺序
查看>>
mysql交互式连接&非交互式连接
查看>>
MySQL什么情况下会导致索引失效
查看>>
Mysql什么时候建索引
查看>>
MySql从入门到精通
查看>>
MYSQL从入门到精通(一)
查看>>
MYSQL从入门到精通(二)
查看>>
mysql以下日期函数正确的_mysql 日期函数
查看>>
mysql以服务方式运行
查看>>
mysql优化--索引原理
查看>>
MySQL优化之BTree索引使用规则
查看>>