平時工做當中常常會遇到數組去重的需求,因此在這裏整理一下有哪些方法能夠實現數組的去重。javascript
function removeSameEle(arr){
let res=[];
for(var i=0,len=arr.length;i<len;i++){
for(var j=0,resLen=res.length;j<resLen;j++){
if(arr[i]===arr[j]){//判斷結果中是否已存在該數據了
break;
}
}
//判斷是否執行到了res的末尾
if(j===resLen){
res.push(arr[i]);
}
}
return res;
}
複製代碼
function removeSameEle(arr){
let res=[];
for(var i=0,len=arr.length;i<len;i++){
//if(!res.includes(arr[i])){
if(res.indexof(arr[i])<0){//判斷結果中是否存在該數據了
res.push(arr[i])
}
}
return res;
}
複製代碼
function removeSameEle(arr){
let res=arr.filter((item,index,arr)=>{
return arr.indexOf(item)===index;
});
return res;
}
複製代碼
function removeSameEle(arr){
return arr.reduce((accu,cur)=>{
return accu.includes(cur)?[...accu]:[...accu,cur]
},[])
})
}
複製代碼
function removeSameEle(arr){
return [...new Set(arr)];
}
複製代碼
function removeSameEle(arr){
let map=new Map();
let res=[];
for(let i=0;len=arr.length;i<len;i++){
if(!map.has(arr[i])){
map.set(arr[i],arr[i]);
res.push(arr[i]);
}
}
return res;
}
複製代碼
function removeSameEle(arr){
let res=[];
let sortedArr=arr.sort();
for(let i=0,len<sortedArr.length;i<len-1;i++){
if(i==0||sortedArr[i]!==sortedArr[i+1]){
res.push(sortedArr[i]);
if(i===(len-2)){
res.push(sortedArr[i+1]);
}
}
}
return res;
}
複製代碼
function removeSameEle(arr){
let res=[];
let obj={};
arr.forEach((item,index)=>{
if(!obj[item]){
obj[item]=item
}
});
for(let value of Object.values(obj)){
res.push(value);
}
return res;
}
複製代碼