1、使用ES6中的 set 去重
var arr = [1, 8, 5, 3, 1, 5, 2, 6];
function only(arr) {
return Array.from(new Set(arr));
}
console.log(only(arr));
显示效果:
2、set 与解构赋值去重
var arr = [1, 8, 5, 3, 1, 5, 2, 6];
function only(arr) {
return [...new Set(arr)];
}
console.log(only(arr));
显示效果:
3、使用双重for循环,结合splice去重:
var arr = [1, 8, 5, 3, 1, 5, 2, 6];
function only(arr) {
let i, j;
for (i = 0; i < arr.length; i++) {
for (j = i + 1; j < arr.length; j++) {
if (arr[i] == arr[j]) {
arr.splice(j, 1);
j--;
}
}
}
return arr;
}
console.log(only(arr));
显示效果:
4、使用indexOf 进行数组去重
var arr = [1, 8, 5, 3, 1, 5, 2, 6];
function only(arr) {
let i, newArr = [];
for (i = 0; i < arr.length; i++) {
if (newArr.indexOf(arr[i]) == -1) {
newArr.push(arr[i]);
}
}
return newArr
}
console.log(only(arr));
显示效果:
5、使用对象键值对进行去重
var arr = [1, 8, 5, 3, 1, 5, 2, 6];
function only(arr) {
let i, newArr = [], obj = {};
for (i = 0; i < arr.length; i++) {
if (!obj[arr[i]]) {
newArr.push(arr[i]);
obj[arr[i]] = 1;
}
}
return newArr
}
console.log(only(arr));
显示效果: