1. filter :
- function unique(arr) {
- return arr.filter(function(item, index, arr) {
- //当前元素,在原始数组中的第一个索引==当前索引值,否则返回当前元素
- return arr.indexOf(item, 0) === index;
- });
- }
- var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
- console.log(unique(arr))
2. ES6 Set去重(ES6中最常用)
- function unique (arr) {
- return Array.from(new Set(arr))
- }
- var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
- console.log(unique(arr))
- //[1, "true", true, 15, false, undefined, null, NaN, "NaN", 0, "a", {}, {}]
3. for嵌套for,然后splice去重(ES5中最常用)
- function unique(arr){
- for(var i=0; i<arr.length; i++){
- for(var j=i+1; j<arr.length; j++){
- if(arr[i]==arr[j]){ //第一个等同于第二个,splice方法删除第二个
- arr.splice(j,1);
- j--;
- }
- }
- }
- return arr;
- }
- var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
- console.log(unique(arr))
- //[1, "true", 15, false, undefined, NaN, NaN, "NaN", "a", {…}, {…}] //NaN和{}没有去重,两个null直接消失了
for in
遍历的是数组的索引(即键名),而for of
遍历的是数组元素值
for in
可以得到对象的key
或数组、字符串的下标
for of
不能直接遍历对象, 可以先通过 Object.keys
得到对象的键再获取值