一、ES6的set()方法(存在兼容问题)
var arr = [1,3,5,222,1,6,5,0]
function unique(arr){
return Array.from(new Set(arr))
}
console.log(unique(arr))
二、for嵌套for,然后用splice(浪费性能)
var arr = [1,3,5,222,1,6,5,0]
function unique(arr){
for(var i=0;i<arr.length-1;i++) {
for(var k = k+1;k<arr.length;k++){
if(arr[i]==arr[k]){
//相等,即重复项,在原有数组中删除
arr.splice(k,1)
//这样做会导致数组塌陷问题:删除重复项后,数组的length会发生改变,此时k累加,拿出来的结果就回跳过一位
k--;//删除后先减减,再加加,相当于没加没减
}
}
}
}
console.log(unique(arr));
三、 indexOf()创建一个新数组,判断新数组中是否存在该元素如果不存在则将此元素添加到新数组中**
var arr = [1,3,5,222,1,6,5,0]
console.log(arr);
function unique(arr){
var temp =[];
for(var i = 0;i<arr.length;i++){
if(temp.indexOf(arr[i])==-1){
temp.push(arr[i])
}
}
return temp;
}
var arr2=unique(arr);
console.log(arr2)
四、 filter 接收回调函数,接受三个参数:某个元素、元素的位置和数组本身:
var arr = [1,3,5,222,1,6,5,0]
function unique(arr){
return arr.filter(function(item,index,self){
return arr.indexOf(item,0) == index;
})
}
console.log(unique(arr))
五、 利用空对象来记录新数组中已经存储过的元素
var arr = [1,3,5,222,1,6,5,0]
var obj={};
var arr2=[];
for(var i =0;i<arr.length;i++){
if(!obj[arr[i]]){
obj[arr[i]]==true;
arr2.push(arr[i])
}
}
console.log(arr2);