数组去重的4种方式

Posted 7cvz9vxk

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数组去重的4种方式相关的知识,希望对你有一定的参考价值。

这是第一篇文章,没什么经验,随便写写,如果对你有用的话,拿小本本记下来哦!如果有不对的地方,请多指教!

1. 利用 indexOf() 方法

var arr = [1, 2, 5, 2, 3, 5]
var result = []
var len = arr.length
for(var i = 0; i < len; i++) {
    if(result.indexOf(arr[i]) < 0) { //判断当前数组下标为[i]的元素是否已经保存在result中
        result.push(arr[i])    // 如果已保存跳过,否则将此元素保存在result数组中
    }
}

2. es6 的 Set() 方法

var arr = [1, 2, 5, 2, 3, 5]
var newArr = new Set(arr)
var result = [...newArr] 
 
或
 
var result = Array.from(newArr)

3. reduce() 方法

var arr = [1, 2, 5, 2, 3, 5]
var result = arr.reduce((ar, cur) => { // ar 结束后的返回值, cur 当前元素
    if(!ar.includes(cur)) { // includes() 用来判断一个数组是否包含一个值,如果是返回true,否则false
        ar.push(cur)
    }
    return ar
}, []) // [] 初始值

4. filter() 方法

var arr = [1, 2, 5, 2, 3, 5]
var result.filter((item, index) => {
    return arr.indexOf(item) === index // 如果这里用 == 的话\'1\'和1会被当做相同元素,所以使用===
})

以上是关于数组去重的4种方式的主要内容,如果未能解决你的问题,请参考以下文章

js实现数组去重的方式(7种)

数组去重的五种方法

刷题 | 数组去重的4种方法引发的思考

数组去重的几种方式

js之数组去重的方法

数组去重的几种方式