关于如何去除一个给定数组中的重复项,应该是 Javascript 面试中最常见的一个问题了,最常见的方式有三种:Set、Array.prototype.filter 以及 Array.prototype.reduce,对于只有简单数据的数组来讲,我最喜欢 Set,没别的,就是写起来简单。
专注于为中小企业提供成都网站建设、成都做网站服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业玉林免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上1000+企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。
- const originalArray = [1, 2, '咩', 1, 'Super Ball', '咩', '咩', 'Super Ball', 4]
- const bySet = [...new Set(originalArray)]
- const byFilter = originalArray.filter((item, index) => originalArray.indexOf(item) === index)
- const byReduce = originalArray.reduce((unique, item) => unique.includes(item) ? unique : [...unique, item], [])
使用 Set
先让我们来看看 Set 到底是个啥
- Set 对象允许你存储任何类型的唯一值,无论是原始值或者是对象引用。
- https://developer.mozilla.org...
const bySet = [...new Set(originalArray)] 这一段的操作,我们将它拆分来看:
- const originalArray = [1, 2, '咩', 1, 'Super Ball', '咩', '咩', 'Super Ball', 4]
- const uniqueSet = new Set(originalArray)
- // 得到 Set(5) [ 1, 2, "咩", "Super Ball", 4 ]
- const bySet = [...uniqueSet]
- // 得到 Array(5) [ 1, 2, "咩", "Super Ball", 4 ]
在将 Set 转为 Array 时,也可以使用 Array.from(set)。
使用 Array.prototype.filter
要理解 filter 方法为什么可以去重,需要关注一下另一个方法 indexOf
- indexOf()方法返回在数组中可以找到一个给定元素的第一个索引,如果不存在,则返回 -1。
- https://developer.mozilla.org...
- const beasts = ['ant', 'bison', 'camel', 'duck', 'bison'];
- console.log(beasts.indexOf('bison'));
- // expected output: 1
- // start from index 2
- console.log(beasts.indexOf('bison', 2));
- // expected output: 4
- console.log(beasts.indexOf('giraffe'));
- // expected output: -1
- filter() 方法创建一个新数组, 其包含通过所提供函数实现的测试的所有元素。
- https://developer.mozilla.org...
filter 方法接受两个参数:
我们将上面的去重方法按下面这样重写一下,就可以看清整个 filter 的执行过程了。
- const originalArray = [1, 2, '咩', 1, 'Super Ball', '咩', '咩', 'Super Ball', 4]
- const table = []
- const byFilter = originalArray.filter((item, index) => {
- // 如果找到的索引与当前索引一致,则保留该值
- const shouldKeep = originalArray.indexOf(item) === index
- table.push({
- 序号: index,
- 值: item,
- 是否应该保留: shouldKeep ? '保留' : '删除'
- })
- return shouldKeep
- })
- console.log(byFilter)
- console.table(table)
使用 Array.prototype.reduce
- reduce() 方法对数组中的每个元素执行一个由您提供的 reducer 函数(升序执行),将其结果汇总为单个返回值。
- https://developer.mozilla.org...
Array.prototype.reduce 方法接受两个参数:
就像 filter 章节一样,我们来看看 reduce 的执行过程:
- const originalArray = [1, 2, '咩', 1, 'Super Ball', '咩', '咩', 'Super Ball', 4]
- const byReduce = originalArray.reduce((unique, item, index, source) => {
- const exist = unique.includes(item)
- const next = unique.includes(item) ? unique : [...unique, item]
- console.group(`遍历第 ${index} 个值`)
- console.log('当前累计器:', unique)
- console.log('当前值:', item)
- console.log('是否已添加进累计器?', exist)
- console.log('新值', next)
- console.groupEnd()
- return next
- }, [])
网站栏目:来一个老生常谈的话题,JavaScript中,数组如何去重?
标题路径:http://www.shufengxianlan.com/qtweb/news28/27278.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联