Methods 1:定義一個(gè)新數(shù)組舆床,并存放原數(shù)組的第一個(gè)元素棋蚌,然后將元素組和新數(shù)組的元素對比,若不同則存放在新數(shù)組中
function unique(arr) {
var res = [arr[0]]; //把數(shù)組第一個(gè)存入新數(shù)組
for (let i = 0; i < arr.length; i++) {
let repeat = false;
for (let k = 0; k < res.length; k++) {
if (res[k] === arr[i]) {
repeat = true;
break;
}
}
if (!repeat) {
res.push(arr[i]);
}
}
return res;
}
Methods 2:先將原數(shù)組排序挨队,在與相鄰的進(jìn)行比較谷暮,不同就插入新數(shù)組中
function unique(arr) {
var tempArr = arr.sort(); //對數(shù)組進(jìn)行排序
var res = [tempArr[0]]; //把數(shù)組第一個(gè)存入新數(shù)組
for (let i = 0; i < tempArr.length; i++) {
if (tempArr[i] !== res[res.length - 1]) {
res.push(tempArr[i]);
}
}
return res;
}
Methods 3:利用對象屬性存在的特性,如果對象沒有該屬性則存入新數(shù)組
function unique(arr) {
var res = [];
var obj = {};
for (let i = 0; i < arr.length; i++) {
if (!obj[arr[i]]) {
obj[arr[i]] = 1;
res.push(arr[i]);
}
}
return res;
}
Methods 4:利用indexOf下標(biāo)判斷數(shù)組是否含有這個(gè)數(shù)字
function unique(arr) {
var res = [];
for (let i = 0; i < arr.length; i++) {
if (res.indexOf(arr[i])===-1) {
res.push(arr[i]);
}
}
return res;
}
Methods 5:利用數(shù)組原型對象上的filter和includes方法
function unique(arr) {
var res = [];
res = arr.filter(function (item) {
return res.includes(item) ? '' : res.push(item);
});
return res;
}
Methods 6:利用ES6的Set方法
function unique6(arr){
//Set數(shù)據(jù)結(jié)構(gòu)盛垦,它類似于數(shù)組湿弦,其成員的值都是唯一的
return Array.from(new Set(arr)); // 利用Array.from將Set結(jié)構(gòu)轉(zhuǎn)換成數(shù)組
}