博客
关于我
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 中的all,5分钟了解MySQL5.7中union all用法的黑科技
查看>>
Mysql 中的日期时间字符串查询
查看>>
MySQL 中锁的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
MySQL 内核深度优化
查看>>