方法一
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