<javaScript> 数组去重的方法总结(2017年)

现在要求去重下面这个数组

const arr = [1, 2, 3, 3, 3, '0', '1', '2', '测试', '重复', '重复', NaN, NaN, false, false];

方法一:ES6 Set()

let arr = [1, 2, 3, 3, 3, '0', '1', '2', '测试', '重复', '重复', NaN, NaN, false, false];
arr = [...new Set(arr)]; //去重后:  [ 1, 2, 3, '0', '1', '2', '测试', '重复', NaN, false ]

Set 是ES6新加的集合,集合中的值不会重复。   ...操作符 会将可遍历对象,转换为数组.

 

方法二:利用对象

复制代码
let arr = [1, 2, 3, 3, 3, '0', '1', '2', '测试', '重复', '重复', NaN, NaN, false, false];
let obj = {};
let temp = [];
for (let i = 0; i < arr.length; i++) {
    let type = Object.prototype.toString.call(arr[i]);  // 不加类型 分不清 1 '1'  若用typeof 只有5种类型 无法区分nu
    if ( !obj[arr[i] + type] ) {
        temp.push( arr[i] );
        obj[ arr[i] + type ] = true; //这里给true 利于代码阅读和判断。  如果给 0,'' ,false ,undefined 都会在if那里判断为 false 不利于代码阅读 
    }
}
console.log(temp)  //去重后:  [ 1, 2, 3, '0', '1', '2', '测试', '重复', NaN, false ]
 
 
复制代码
http://www.tianya.cn/128403784

 

 

方法三:sort排序后 在去重

复制代码
let arr = [1, 2, 3, 3, 3, '0', '1', '2', '测试', '重复', '重复', NaN, NaN, false, false];
arr = arr.sort();
let temp = [];
while (arr.length > 0) {
    if ( Object.is(arr[0], arr[1]) ) {  //Object.is() 用于比较2个值, 比===更靠谱   例如 Object.is(NaN,NaN) 会判断true 
        arr.shift();   
    } else {
        temp.push( arr.shift() );
    }
}
//此方法会清空原数组,  你可以复制个数组,在去进行操作  
console.log(temp)  //去重后:  [ '0', 1, '1', '2', 2, 3, NaN, false, '测试', '重复' ]
复制代码

 

方法四:for in 

复制代码
let arr = [1, 2, 3, 3, 3, '0', '1', '2', '测试', '重复', '重复', NaN, NaN, false, false];
let temp = [];
for (let i = 0; i < arr.length; i++) {
    if ( !temp.includes(arr[i]) ) { //includes 检测数组是否有某个值 内部调用Object.is() 利用判断NaN
        temp.push(arr[i]);
    }
}
console.log(temp); //去重后:  [ 1, 2, 3, '0', '1', '2', '测试', '重复', NaN, false ]
复制代码
http://www.tianya.cn/128403752

 

以上方法 在最新版本谷歌浏览器全部正常运行;    建议大家都用谷歌浏览器~~

但是还是要用Babel去转译这些代码 ,不然低级浏览器没法运行。

欢迎大家一起讨论, 提出新的去重方法。       

由任何错误,请在评论指出。  谢谢大家。

(完)

















  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值