实现数组去重的方法很多,最原始的方法是一个值一个值的去遍历,写到空数组里面:
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);
更少的代码达到了相同的效果