博客
关于我
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中的undo log、redo log 、binlog大致概要
查看>>
Mysql中的using
查看>>
MySQL中的关键字深入比较:UNION vs UNION ALL
查看>>
mysql中的四大运算符种类汇总20多项,用了三天三夜来整理的,还不赶快收藏
查看>>
mysql中的字段如何选择合适的数据类型呢?
查看>>
MySQL中的字符集陷阱:为何避免使用UTF-8
查看>>
mysql中的数据导入与导出
查看>>
MySQL中的时间函数
查看>>
mysql中的约束
查看>>
MySQL中的表是什么?
查看>>
mysql中穿件函数时候delimiter的用法
查看>>
Mysql中索引的分类、增删改查与存储引擎对应关系
查看>>
Mysql中索引的最左前缀原则图文剖析(全)
查看>>
MySql中给视图添加注释怎么添加_默认不支持_可以这样取巧---MySql工作笔记002
查看>>
Mysql中获取所有表名以及表名带时间字符串使用BetweenAnd筛选区间范围
查看>>
Mysql中视图的使用以及常见运算符的使用示例和优先级
查看>>
Mysql中触发器的使用示例
查看>>
Mysql中设置只允许指定ip能连接访问(可视化工具的方式)
查看>>
mysql中还有窗口函数?这是什么东西?
查看>>
mysql中间件
查看>>