1.9 数组去重方法

时间:2021-06-28 19:05:03
方法一
function combine(){ 
    let arr = [].concat.apply([], arguments);  //没有去重复的新数组 
//arguments 是一个对应于传递给函数的参数的类数组对象。
//1.arguments像是一个默认参数 它可以拿到调用函数传入的实参数。并用类数组形式拿到。可以用索引下标引用。设置。
//2.使用范围为非箭头函数
//3.还可以用length
//4这种技术对于可以传递可变数量的参数的函数很有用。使用 arguments.length来确定传递给函数参数的个数,然后使用arguments对象来处理每个参数。要确定函数签名中(输入)参数的数量,请使用Function.length属性。
    return Array.from(new Set(arr));
} //Array.from() 方法从一个类似数组或可迭代对象中创建一个新的数组实例。
// concat() 方法用于合并两个或多个数组。此方法不会更改现有数组,而是返回一个新数组
var m = [1, 2, 2], n = [2,3,3]; 
console.log(combine(m,n)); 
 

//arguments还有很多好功能 有机会研究一下

方法二

 

Array.prototype.distinct = function (){
    var arr = this,
        i,
        j,
        len = arr.length;
 
    for(i = 0; i < len; i++){
        for(j = i + 1; j < len; j++){
            if(arr[i] == arr[j]){
                arr.splice(j,1); //利用splice直接在原数组进行操作,删除相同值时,数组长度相应减一。

但是,我们要注意的是,此种方法会改变原数组的值,也就是说,我们改变了arr的结果。如果不想改变原数组改怎么办呢?
                len--;
                j--;
            }
        }
    }
    return arr;
};
 
var a = [1,2,3,4,5,6,5,3,2,4,56,4,1,2,1,1,1,1,1,1,];
var b = a.distinct();
console.log(b.toString()); //1,2,3,4,5,6,56