使用js里面的迭代器filter實現數組去重


實現數組去重的方法很多,最原始的方法是一個值一個值的去遍歷,寫到空數組里面:

let r=[],arr = ['a', 'b', 'c', 'a'];
for(var i=0,len=arr.length;i<len;i++){
    if(r.indexOf(arr[i])===-1){
        r.push(arr[i]);
    }
}

 或者是在es6里面的.map方法,

但是今天要講的是迭代器filter,用習慣了迭代器,你可以發現它真的可以取代for循環干許多的事情,而且代碼簡潔,

filter的定義:

filter():對數組中的每一項運行給定函數。返回該函數會返回true的項組成的數組。

代碼如下:

 arr = ['a', 'b', 'c', 'a'];
  let arr2=arr.filter((item,index,self)=>{return self.indexOf(item) == index;});
  console.log(arr2);

  更少的代碼達到了相同的效果


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM