理由es6实现数组去重

news/2024/7/10 22:38:11 标签: javascript, es6

以下是三种方法从数组里去重,并且返回唯一的值。我最喜欢的方式是使用Set,因为它是最短最简单的。

javascript">const array = [5, 2, 4, 5, 3];
console.log([...new Set(array)])
console.log(array.filter((item, index) => array.indexOf(item) === index))
console.log(array.reduce((unique, item) => unique.includes(item) ? unique: [...unique, item], []))
// result:  [5, 2, 4, 3]

使用Set

让我开始解释Set是什么吧:

Set是由es6引入的一种新的数据对象,由于Set只允许你存储唯一值,所以当传递进去一个数组的时候,它将会移除任何重复的值。

好啦,然我们回到我们的代码中来看下到底都发生了什么。实际上他进行了以下的操作:

首先,我们创建了新的Set并且把数组当作入参传递了进去,由于Set仅仅允许唯一值,所以所有重复值将会被移除。
现在重复值已经消失了,我们将会利用…把它重新转为数组。

javascript">const array = [5, 2, 4, 5, 3];
const set = new Set(array)
const newArr = [...set]
console.log(newArr)
// result:  [5, 2, 4, 3]

使用Array.from()函数来吧Set转为数组

另外呢,你也可以使用Array.from()来吧Set转为数组。

javascript">const array = [5, 2, 4, 5, 3];
const set = new Set(array)
const newArr = Array.from(set)
console.log(newArr)
// result:  [5, 2, 4, 3]

使用filter

为了理解这个选项,让我们来看看这两个方法都做了什么:indexOf和filter

indexOf()

indexOf()返回我们从数组里找到的第一个元素的索引。

javascript">const array = [5, 2, 4, 5, 3];
console.log(array.indexOf(5))  // 0
console.log(array.indexOf(2))  // 1
console.log(array.indexOf(8))  // -1

filter

filter()函数会根据我们提供的条件创建一个新的数组。换一种说法,如果元素通过并且返回true,它将会包含在过滤后的数组中,如果有元素失败并且返回false,那么他就不会包含在过滤后的数组中。

我们逐步看看在每次循环数组的时候都发生了什么。

javascript">const array = [5, 2, 4, 5, 3];
array.filter((item, index) => {
  console.log(item, index, array.indexOf(item), array.indexOf(item) === index)
  return array.indexOf(item) === index
})
//输出
// 5 0 0 true
// 2 1 1 true
// 4 2 2 true
// 5 3 0 false
// 3 4 4 true

上面输出的代码见注释。重复的元素不再于indexOf相匹配,所以在这些情况下,它的结果将会是false并且将不会被包含进过滤后的值当中。

检索重复的值

我们也可以在数组中利用filter()函数来检索重复的值。我们只需要像这样简单的调整下代码:

javascript">const array = [5, 2, 4, 5, 3];
array.filter((item, index) => {
  console.log(item, index, array.indexOf(item), array.indexOf(item) !== index)
  return array.indexOf(item) !== index
})
//输出
// 5 0 0 false
// 2 1 1 false
// 4 2 2 false
// 5 3 0 true
// 3 4 4 false

使用reduce()函数

reduce()函数用于减少数组的元素并根据你传递过去的reducer函数,把他们最终合并到一个最终的数组中,

在这种情况下,我们的reducer()函数我们最终的数组是否包含了这个元素,如果不包含,就吧他放进最终的数组中,反之则跳过这个元素,最后再返回我们最终的元素。

reduce()函数理解起来总是有那么一点费劲,所以呢,咱们现在看下他是怎么运行的。

javascript">const array = [5, 2, 4, 5, 3];
array.reduce((unique, item) => {
  console.log(item, unique, unique.includes(item), unique.includes(item) ? unique: [...unique, item])
  return unique.includes(item) ? unique: [...unique, item]
}, [])
//输出
// 5 []          false   [5]
// 2 [5]         false   [5, 2]
// 4 [5, 2]      false   [5, 2, 4]
// 5 [5, 2, 4]   true    [5, 2, 4]
// 3 [5, 2, 4]   false   [5, 2, 4, 3]

转载自:https://segmentfault.com/a/1190000017902898


http://www.niftyadmin.cn/n/1681275.html

相关文章

788. 逆序对的数量(归并算法)

788. 逆序对的数量 给定一个长度为 n 的整数数列&#xff0c;请你计算数列中的逆序对的数量。 逆序对的定义如下&#xff1a;对于数列的第 i 个和第 j 个元素&#xff0c;如果满足 i<j 且 a[i]>a[j]&#xff0c;则其为一个逆序对&#xff1b;否则不是。 输入格式 第一…

编程 给文件加锁_并发编程_1_Synchronized

Synchronized 在多线程并发编程中 synchronized 一直是元老级角色&#xff0c;我们在开发过程中可以使用它来解决线程安全问题中提到的原子性&#xff0c;可见性&#xff0c;以及有序性。很多人都会称呼它为重量级锁。但是&#xff0c;随着Java SE 1.6对 synchronized 进行了各…

idea 如何加入插件SonarLint

idea 如何加入插件SonarLint IDEA的插件安装有两种方法&#xff1a;一是在线安装&#xff1b;二是离线安装&#xff0c;即将插件的安装包下载以后从本地安装。 一、在线安装的过程&#xff1a; 1、打开IDEA&#xff0c;选择"File"下的"Settings"&#xff1…

var与let的区别

当用let声明一个变量&#xff0c;它使用的是词法作用域或块作用域。不同于使用 var声明的变量那样可以在包含它们的函数外访问&#xff0c;块作用域变量在包含它们的块或for循环之外是不能访问的。当let声明出现在循环体里时拥有完全不同的行为。不仅是在循环里引入了一个新的变…

poj 3692(二分图匹配--最大独立集)

题意&#xff1a;有一些男生女生互相了解&#xff0c;要求选出最大的学生之间互相了解。 思路&#xff1a;只需要将不了解的学生之间建边就可转化成最大独立集问题 &#xff1a; 结点数-二分图最大匹配。 直接套模版就可 代码如下&#xff1a; 1 /****************************…

今天将网易博客的内容迁过来

今天才发现去年的网易博客内容没有迁过来&#xff0c;今天迁过来 转载于:https://www.cnblogs.com/programer-xinmu78/p/10661116.html

php做网站步骤_SEO网站优化怎么做?超详细的SEO优化步骤和技巧分享

SEO 网站优化的步骤和技巧有哪些&#xff1f;这个问题困扰的都是一些刚入行SEO的新手朋友呢&#xff01;因为每一个对于SEO有自己的理解的老手使用的优化步骤和技巧都不一样&#xff0c;每一个SEOer对于如何优化一个网站的理解都是不同的。我就以一个刚入职的SEO专员为视角&…

看电脑支持内存大小

出命令提示符窗口后&#xff0c;输入命令wmic memphysical get maxcapacity并按回车&#xff0c;这时会出现一串数字&#xff0c;出现的数字就是主板支持最大的内存大小&#xff0c;但是单位是KB。 转载于:https://www.cnblogs.com/programer-xinmu78/p/10661121.html