数组去重

/*//1.常规的方法

var arr = [1,2,31,1,1,,4];
//在数组原型上绑定方法

Array.prototype.unique = function() {
    //提出数组中一个值
    var res = [this[0]];
    //遍历数组
    for(var i = 1; i < this.length; i++) {
        //做个标记
        var repeat = false;
        //遍历空数组,并有重复数据时将开关关掉
        for( var j = 0; j < res.length; j++) {

            if(this[i] == res[j]) {
                repeat = true;
                break;
            }

        }
        if(!repeat) {
            res.push(this[i]);
        }
    }
    return res;

}
alert(arr.unique());*/

var arr = [1,3,1,31,1];




//2.先把原数组排序,这样重复的数值会相邻,再将数组中前后两项进行对比
/*Array.prototype.unique = function() {
    this.sort();
    var res = [this[0]];
    //数组前后两项对比
    for(var i = 0;i < this.length; i++){
        if(this[i] != res[res.length - 1]) {
            res.push(this[i]);
        }
    }

    return res;
}

alert(arr.unique());*/

//3.放入对象的属性中.利用空对象的属性判断代替了第一种方法中的开关

/*Array.prototype.unique = function() {
    var res = [];
    var obj = {};
    for(var i = 0; i< this.length; i++) {

        if(!obj[this[i]]) {
            res.push(this[i]);
            obj[this[i]] = 1;
        }
    }

    return res;
}

alert(arr.unique());*/

//4.
// ES6
/*function unique (arr) {
  const seen = new Map()
  return arr.filter((a) => !seen.has(a) && seen.set(a, 1))
}
// or
function unique (arr) {
  return Array.from(new Set(arr))
}*/

//5. ES6新方法
console.log(Array.from(new Set(arr)));


//6. 使用indexOf方法
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值