方法一
创建一个数组arr2,遍历需要去重的数组arr,如果arr2里面没有这个元素就push进去。
var arr = [1,2,3,1,2],
arr2 = [];
arr.forEach(element => {
if(arr2.indexOf(element) === -1){
arr2.push(element);
}
});
var arr = [1,2,3,1,2],
arr2 = [];
arr.forEach(element => {
if(!arr2.includes(element)){
arr2.push(element);
}
});
方法二(ES6)
创建集合时可以传递一个数组,数组的所有元素将不重复地被添加到新的集合中。而集合的元素是不重复的,因此可以通过集合来进行去重,最后用三点运算符把集合转化为数组。
var arr = [1,2,3,1,2];
var set = new Set(arr);
var arr2 = [...set];
方法三
如果当前数组的第 i 项在当前数组中第一次出现的位置不是 i,那么表示第 i 项是重复的,忽略掉。否则存入结果数组。
var arr = [1,2,3,1,2],
arr2 = [];
arr.forEach((element , index) => {
if(arr.indexOf(element) === index){
arr2.push(element);
}
});
var arr = [1,2,3,1,2];
var arr 2 = arr.filter((element , index) => arr.indexOf(element) === index);
方法四
给传入的数组排序,排序后相同的值会相邻,然后遍历排序后数组时,新数组只加入不与前一值重复的值。
var arr = [1,2,3,1,2],
arr2 = [];
arr.sort((a,b) => a - b);
arr2.push(arr[0]);
for(var i = 1; i < arr.length; i++){
if(arr[i] !== arr[i - 1]){
arr2.push(arr[i]);
}
}