一、es6 set
ES6 提供了新的數據結構 Set。它相似於數組,可是成員的值都是惟一的,沒有重複的值。
let arr = [1,2,3,4,3,2,3,4,6,7,6];
let unique = (arr)=> [...new Set(arr)];
unique(arr);//[1, 2, 3, 4, 6, 7]
二、es6 map
思路爲map對象裏沒有數組元素的屬性,就在map對象裏添加數組元素的屬性,並賦值爲1,而後在過濾。
let arr = [1,2,3,4,3,2,3,4,6,7,6];
let unique = (arr)=> {
let seen = new Map();
return arr.filter((item) => {
return !seen.has(item) && seen.set(item,1);
});
};
unique(arr);
三、for 雙重循環
經過判斷第二層循環,去重的數組中是否含有該元素,若是有就退出第二層循環,若是沒有j==result.length就相等,而後把對應的元素添加到最後的數組裏面。
let arr = [1,2,3,4,3,2,3,4,6,7,6];
let result = [];
for(var i = 0 ; i < arr.length; i++) {
for(var j = 0 ; j < result.length ; j++) {
if( arr[i] === result[j]){
break;
};
};
if(j == result.length){
result.push(arr[i]);
};
};
console.log(result);
四、indexOf
indexOf() 方法可返回某個指定的元素在數組中首次出現的位置。若是沒有就返回-1。
let arr = [1,2,3,4,3,2,3,4,6,7,6];
let unique = (arr) => {
let result = [];
for( var i = 0 ; i < arr.length ; i++){
if(result.indexOf(arr[i]) == -1){
result.push(arr[i])
}
};
return result;
};
unique(arr);
五、indexOf filter
let arr = [1,2,3,4,3,2,3,4,6,7,6];
let unique = (arr) => {
return arr.filter((item,index) => {
return arr.indexOf(item) === index;
})
};
unique(arr);
六、排序後去重
先數組排序,而後判斷是不是第一個元素而且前一個元素是否和後一個元素相同,不一樣就加進新數組
let arr = [1,2,3,4,3,2,3,4,6,7,6];
let unique = (arr) => {
let arrNew = arr.sort((a,b)=>a-b);
let seen,result = [];
for(var i = 0 ; i < arrNew.length ;i++){
if(!seen || seen != arrNew[i]){
result.push(arrNew[i]);
};
seen = arrNew[i]
};
return result;
};
unique(arr);