實現數組去重的方法很多,最原始的方法是一個值一個值的去遍歷,寫到空數組里面:
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);
更少的代碼達到了相同的效果