js数组去重效率最高的方法(js数组遍历的三种方法)

技术七种JS实现数组去重的方式分别是什么这篇文章将为大家详细讲解有关七种JS实现数组去重的方式分别是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。例:将下面数组去除重

本文将详细讲解实现阵列重复数据消除的七种JS方式,文章内容质量较高,所以边肖将分享给大家参考。希望你看完这篇文章后有所了解。

例:下面的数组中删除重复的元素(以多种数据类型为例)

Constarr=[1,2,2,' ABC ',' ABC ',true,true,false,false,undefined,undefined,nan,nan]

1.利用Set()+Array.from()

Set对象:是一个值的集合,可以按照插入的顺序迭代它的元素。集合中的元素只会出现一次,也就是说,集合中的元素是唯一的。

Array.from() 方法:为类似的数组或可迭代对象创建一个新的浅拷贝数组实例。

construsult=array . from(newSet(arr))

Console.log (result)//[1,2,' ABC ',true,false,undefined,NaN]注意:对于NaN和undefined类型的去重也是有效的,因为NaN和undefined都可以存储在Set中,NaN被认为是相同的值(虽然在js: Nan中!==NaN).

00-1010通过两层循环逐一比较数组元素,然后通过拼接方法删除重复的元素。这个方法不能复制NaN,因为NaN!==NaN .

function remove duplicate(arr){ 0

letlen=arr.length

for(leti=0;伊琳;I){ 0

for(letj=I 1;jlenj ){

if(arr[i]===arr[j])

arr.splice(j,1)

len-///减少周期数以提高性能

J-///保证J的值相加后不变。

}

}

}

返回

}

construction sult=remove duplicate(arr)

Console.log (result)//[1,2,' ABC ',true,false,undefined,nan,nan]

2.利用两层循环+数组的splice方法

创建一个新的空数组,遍历需要复制的数组,并将数组元素存储到新数组中。存储前,判断数组是否已经包含当前元素,如果没有,则存储。这个方法也不能复制NaN。

indexOf() 方法:函数返回调用它的String对象中指定值的第一个匹配项的索引,并从fromIndex中进行搜索。如果找不到该值,则返回-1。

rush:js;">function removeDuplicate(arr) {

   const newArr = []

   arr.forEach(item => {

     if (newArr.indexOf(item) === -1) {
     newArr.push(item)
    }
 })
 return newArr // 返回一个新数组
}

const result = removeDuplicate(arr)
console.log(result) // [ 1, 2, 'abc', true, false, undefined, NaN, NaN ]

4.利用数组的includes方法

此方法逻辑与indexOf方法去重异曲同工,只是用includes方法来判断是否包含重复元素。

includes()方法:用来判断一个数组是否包含一个指定的值,根据情况,如果包含则返回 true,否则返回 false。

 function removeDuplicate(arr) {

    const newArr = []

    arr.forEach(item => {

       if (!newArr.includes(item)) {
       newArr.push(item)
      }
   })
  return newArr
 }

 const result = removeDuplicate(arr)

 console.log(result) // [ 1, 2, 'abc', true, false, undefined, NaN ]

注意:为什么includes能够检测到数组中包含NaN,其涉及到includes底层的实现。如下图为includes实现的部分代码,在进行判断是否包含某元素时会调用sameValueZero方法进行比较,如果为NaN,则会使用isNaN()进行转化。

简单测试includes()对NaN的判断:

const testArr = [1, 'a', NaN]
console.log(testArr.includes(NaN)) // true

5.利用数组的filter()+indexOf()

filter方法会对满足条件的元素存放到一个新数组中,结合indexOf方法进行判断。

filter() 方法:会创建一个新数组,其包含通过所提供函数实现的测试的所有元素。

 function removeDuplicate(arr) {

    return arr.filter((item, index) => {

       return arr.indexOf(item) === index
  })
}

const result = removeDuplicate(arr)

console.log(result) // [ 1, 2, 'abc', true, false, undefined ]

注意:这里的输出结果中不包含NaN,是因为indexOf()无法对NaN进行判断,即arr.indexOf(item) === index返回结果为false。测试如下:

const testArr = [1, 'a', NaN]
console.log(testArr.indexOf(NaN)) // -1

6.利用Map()

Map对象是JavaScript提供的一种数据结构,结构为键值对形式,将数组元素作为map的键存入,前端培训然后结合has()和set()方法判断键是否重复。

Map 对象:用于保存键值对,并且能够记住键的原始插入顺序。任何值(对象或者原始值)都可以作为一个键或一个值。

function removeDuplicate(arr) {

const map = new Map()

const newArr = []

arr.forEach(item => {

  if (!map.has(item)) { // has()用于判断map是否包为item的属性值

    map.set(item, true) // 使用set()将item设置到map中,并设置其属性值为true
  
    newArr.push(item)
  }
})

return newArr
}

const result = removeDuplicate(arr)

console.log(result) // [ 1, 2, 'abc', true, false, undefined, NaN ]

注意:使用Map()也可对NaN去重,原因是Map进行判断时认为NaN是与NaN相等的,剩下所有其它的值是根据 === 运算符的结果判断是否相等。

7.利用对象

其实现思想和Map()是差不多的,主要是利用了对象的属性名不可重复这一特性。

function removeDuplicate(arr) {

   const newArr = []

   const obj = {}

   arr.forEach(item => {

       if (!obj[item]) {
       newArr.push(item)
       obj[item] = true
      }
   })

   return newArr
 }

 const result = removeDuplicate(arr)

 console.log(result) // [ 1, 2, 'abc', true, false, undefined, NaN ]

关于七种JS实现数组去重的方式分别是什么就分享到这里了,希望

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/144816.html

(0)

相关推荐

  • leetcode 数组出现最多的数(leetcode数组加减乘除)

    技术LeetCode如何调整数组顺序使得奇数位于偶数前面这篇文章主要介绍LeetCode如何调整数组顺序使得奇数位于偶数前面,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!题目:输入一个整数数组,实

    攻略 2021年12月15日
  • Alibaba Sentinel LeapArray源码分析

    技术Alibaba Sentinel LeapArray源码分析这篇文章主要介绍“Alibaba Sentinel LeapArray源码分析”,在日常操作中,相信很多人在Alibaba Sentinel LeapArr

    攻略 2021年11月17日
  • 手工纸灯笼制作,幼儿园手工制作灯笼需要什么材

    技术手工纸灯笼制作,幼儿园手工制作灯笼需要什么材准备材料手工纸灯笼制作:一次性纸杯两只,红线若干,剪刀,胶水或双面胶,放焰火剩余的手柄,红色颜料和水粉笔。具体步骤:1.取一只纸杯,尽量选择横竖有参考图案的。沿纵向条纹均匀

    生活 2021年10月30日
  • 怎么理解MySQL的innodb_flush_method

    技术怎么理解MySQL的innodb_flush_method这篇文章主要讲解了“怎么理解MySQL的innodb_flush_method”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一

    攻略 2021年11月19日
  • PyTorch 常用函数备忘

    技术PyTorch 常用函数备忘 PyTorch 常用函数备忘PyTorch 常用函数备忘
    # basic operation
    x: torch.Tensor
    x.shape - torch.Size

    礼包 2021年12月2日
  • 服务器租用香港哪家比较好USA-IDC

    技术服务器租用香港哪家比较好USA-IDC无论您正在构建哪种类型的网站,服务器方面的硬件投入。尤其是对于海外建站热门的香港服务器租用业务来说,选择的香港服务器不同,可能对网站产生质的区别,那么香港服务器租用哪家比较好,如

    礼包 2021年12月23日