美文网首页
四种数组去重方式

四种数组去重方式

作者: 我是Msorry | 来源:发表于2021-01-02 08:54 被阅读0次

本篇文章的API兼容情况数据来源 https://caniuse.com/ 时间为2020.12.30

两次遍历去重

function unique(array){
  for(let i=0; i<array.length; i++){ 
    for(let j=i+1; j<array.length; j++){ 
      if(array[i]===array[j]){ 
        array.splice(j,1); 
        j--; //数组删除元素后指针回退
      }  
    } 
  } 
  return array; 
}

缺点:无法去重 NaN

Set

let unique = (array) => {
    return [...new Set(array)] 
    // 或者 return Array.from(new Set(array))
}

方案二缺点:API 太新,旧浏览器和目前手机端浏览器不支持

Map

let unique = (array) => {
  let map = new Map();
  let result = []
  for (let i = 0; i < array.length; i++) {
    if(map.has(array[i])) { // 判断 map 中是否已有该 key 
      continue
    } else {  // 如果 map 中没有该 key,就加入 result 中
      map.set(array[i], true);  
      result.push(array[i]);
    }
  } 
  return result;
}

方案三缺点:API 太新,旧浏览器和目前手机端浏览器不支持

reduce + includes

function unique(array){ 
  return array.reduce((prev,cur) => prev.includes(cur) ? prev : [...prev,cur],[]); 
} 

方案四缺点:API 较新,手机端旧浏览器不支持

相关文章

  • 数组去重四种方式

    1.使用indexof2.使用开关思想3.使用对象的属性名不能重复检测4.使用冒泡排序的方法

  • 数组的去重和数组中对象的去重

    数组中对象去重 方式1 jq方式 方式2 原生js方式 普通数组的去重 方式1 普通的数组去重js 方式2 Se...

  • 四种数组去重方式

    本篇文章的API兼容情况数据来源 https://caniuse.com/[https://caniuse.com...

  • 数组去重的几种方式

    上篇我们写到了数组中包含多条对象的去重方式数组中包含多条对象的去重方式,今天我们就写一下普通数组去重吧. 数组去重...

  • 数组去重封装

    上次写到了数组去重的几种方式数组去重的几种方式,那么今天就让我们来封装一下数组去重吧。 就在数组原型上封装吧! 源...

  • 数组去重

    优雅的数组去重方式

  • 常用数组去重

    数组去重方式 快速排序

  • JS数组去重方式

    1.ES6去重 2.使用indexOf()方法 3.数组forEach方法 4.添加原型方法

  • 数组去重多重方式

    1. Set(最常用) 2. Map 3. Array.prototype.indexOf() 4.Array.p...

  • v-for遍历四种数据

    v-for的四种使用方式 1、数组 2、对象数组 3、对象 4、迭代数字 总结 v-for的四种使用方式 1、数组...

网友评论

      本文标题:四种数组去重方式

      本文链接:https://www.haomeiwen.com/subject/zqvfoktx.html