比较简单的去重方法一
方法一
要调用indexOf
如果当前数组的第i项在当前数组中出现的位置不是i,那么就是重复项,是i那就存入数组
function arr(num) {
var temp = []; //定义一个临时空数组好保存当前数组
for(var i = 0; i < num.length; i++) {
//如果当前数组的第i项在当前数组中第一次出现的位置是i,才存入数组;否则代表是重复的
if(num.indexOf(num[i]) == i) {
temp.push(num[i])
}
}
return temp;
}
var aa = [1, 2, "2", 4, 9, "a", "a", 2, 3, 5, 6, 5];
console.log(arr(aa));
方法二
在做数组的遍历时,有一个小技巧,就是在遍历即将结束的时候,令index = -1,可以继续遍历,而indexOf代表了数组的下标。
function arrayRepeat(){
var arr=[1,2,3,3,4,4,5,5,6,1,9,3,25,4];
var noRepeatArray = [];
for(var i = 0; i < arr.length; i++){
//在查询中,如果没有查找到重复的结果,就会返回-1,表示没有查找到,然后就加入到那个临时数组里;反之,要是找到有相同的,就不会返回-1,然后就不会加入临时数组里
if(noRepeatArray.indexOf(arr[i]) == -1){
noRepeatArray.push(arr[i]);
}
}
return noRepeatArray;
}
var myArray = arrayRepeat();
for(var j = 0; j < myArray.length; j++){
console.log(myArray[j]);
}