加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 建站 > 正文

来一个老生常谈的话题,JavaScript中,数组怎样去重?

发布时间:2019-08-27 02:54:11 所属栏目:建站 来源:大胡子民工潘半仙
导读:关于怎样去除一个给定命组中的一再项,应该是 Javascript 口试中最常见的一个题目了,最常见的方法有三种:Set、Array.prototype.filter 以及 Array.prototype.reduce,对付只有简朴数据的数组来讲,我最喜好 Set,没此外,就是写起来简朴。 constoriginal
副问题[/!--empirenews.page--]

来一个老生常谈的话题,JavaScript中,数组怎样去重?

关于怎样去除一个给定命组中的一再项,应该是 Javascript 口试中最常见的一个题目了,最常见的方法有三种:Set、Array.prototype.filter 以及 Array.prototype.reduce,对付只有简朴数据的数组来讲,我最喜好 Set,没此外,就是写起来简朴。

  1. const originalArray = [1, 2, '咩', 1, 'Super Ball', '咩', '咩', 'Super Ball', 4] 
  2. const bySet = [...new Set(originalArray)] 
  3. const byFilter = originalArray.filter((item, index) => originalArray.indexOf(item) === index)  
  4. const byReduce = originalArray.reduce((unique, item) => unique.includes(item) ? unique : [...unique, item], []) 

行使 Set

先让我们来看看 Set 到底是个啥

  1. Set 工具应承你存储任何范例的独一值,无论是原始值可能是工具引用。 
  2. <cite>https://developer.mozilla.org...</cite> 
  • 起首,Set 中只应承呈现独一值
  • 独一性是比对原始值可能工具引用

const bySet = [...new Set(originalArray)] 这一段的操纵,我们将它拆分来看:

  1. const originalArray = [1, 2, '咩', 1, 'Super Ball', '咩', '咩', 'Super Ball', 4]  
  2. const uniqueSet = new Set(originalArray) 
  3. // 获得 Set(5) [ 1, 2, "咩", "Super Ball", 4 ] 
  4. const bySet = [...uniqueSet] 
  5. // 获得 Array(5) [ 1, 2, "咩", "Super Ball", 4 ] 

在将 Set 转为 Array 时,也可以行使 Array.from(set)。

行使 Array.prototype.filter

要领略 filter 要领为什么可以去重,必要存眷一下另一个要领 indexOf

  1. indexOf()要领返回在数组中可以找到一个给定元素的第一个索引,假如不存在,则返回 -1。 
  2. <cite>https://developer.mozilla.org...</cite> 
  1. const beasts = ['ant', 'bison', 'camel', 'duck', 'bison']; 
  2. console.log(beasts.indexOf('bison')); 
  3. // expected output: 1 
  4. // start from index 2 
  5. console.log(beasts.indexOf('bison', 2)); 
  6. // expected output: 4 
  7. console.log(beasts.indexOf('giraffe')); 
  8. // expected output: -1 
  1. filter() 要领建设一个新数组, 其包括通过所提供函数实现的测试的全部元素。 
  2. <cite>https://developer.mozilla.org...</cite> 

filter 要领接管两个参数:

  • 第一个参数:一个回调函数, filter 会将数据中的每一项都转达给该函数,若该函数返回 真值,则数据生涯,返回 假值,则数据将不会呈此刻新天生的数据中
  • 第二个参数:回调函数中 this 的指向

我们将上面的去重要领按下面这样重写一下,就可以看清整个 filter 的执行进程了。

  1. const originalArray = [1, 2, '咩', 1, 'Super Ball', '咩', '咩', 'Super Ball', 4] 
  2. const table = [] 
  3. const byFilter = originalArray.filter((item, index) => { 
  4.   // 假如找到的索引与当前索引同等,则保存该值 
  5.   const shouldKeep = originalArray.indexOf(item) === index 
  6.   table.push({ 
  7.     序号: index, 
  8.     值: item, 
  9.     是否应该保存: shouldKeep ? '保存' : '删除' 
  10.   }) 
  11.   return shouldKeep 
  12. })  
  13. console.log(byFilter) 
  14. console.table(table) 

来一个老生常谈的话题,JavaScript中,数组怎样去重?

行使 Array.prototype.reduce

  1. reduce() 要领对数组中的每个元素执行一个由您提供的 reducer 函数(升序执行),将其功效汇总为单个返回值。 
  2. <cite>https://developer.mozilla.org...</cite> 

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读