美文网首页
最常用数组去重方法

最常用数组去重方法

作者: 长街漫步 | 来源:发表于2018-12-26 10:46 被阅读0次

1、利用ES6方法 set

var arr = [1,2,3,3,3,3,4,4,5,6,7]
function unique(arr) {
    return Array.from(new Set(arr))
}
console.log(unique(arr)); // => [ 1, 2, 3, 4, 5, 6, 7 ]

2、for循环 splice去重 去重

var arr = [1,2,3,3,3,3,4,4,5,6,7]
function unique(arr) {
    for (var i = 0; i < arr.length; i++) {
        for (var j = i+1; j < arr.length; j++) {
            if (arr[i] === arr[j]) {
                arr.splice(j,1);
                j--
            }
        }
    }
    return arr
}
console.log(unique(arr)); // => [ 1, 2, 3, 4, 5, 6, 7 ]

3、利用indexOf去重

var arr = [1,2,3,3,3,3,4,4,5,6,7]
function unique(arr) {
    const array = []
    for(const x of arr) {
        if (array.indexOf(x) === -1) {
            array.push(x)
        }
    }
    return array
}
console.log(unique(arr)); // => [ 1, 2, 3, 4, 5, 6, 7 ]

4、...new Set(arr)

var arr = [1,2,3,3,3,3,4,4,5,6,7]
console.log([...new Set(arr)]);// => [ 1, 2, 3, 4, 5, 6, 7 ]

5、利用sort()方法

var arr = [1, 2, 3, 3, 3, 3, 4, 4, 5, 6, 7]

function unique(arr) {
    arr = arr.sort()
    var array = [arr[0]];
    for (var i = 1; i < arr.length; i++) {
        if (arr[i] !== arr[i-1]) {
            array.push(arr[i])
        }
    }
    return array
}
console.log(unique(arr)); // => [ 1, 2, 3, 4, 5, 6, 7 ]

相关文章

  • 数组

    数组 数组常用方法 数组去重

  • 数组去重

    分类 非对象数组去重 对象数组去重 分类一 --- 非对象数组去重 方法一: set(es6常用) 方法二:red...

  • JavaScript数组去重

    JavaScript中数组的常用操作之数组去重 方法一 方法二

  • 数组去重

    1.利用ES6 Set去重(ES6中最常用) 2.它是最简单的数组去重方法(indexOf方法) 3.优化遍历数组...

  • 数组去重的几种方法

    数组去重的几种方法 ES6 Set去重(ES6常用) -不修改原数组 不考虑兼容性,这种去重的方法代码最少。这种方...

  • 关于数组

    数组的创建 数组的小方法 常用方法 1、清空一个数组 2、删除数组中的偶数 3、数组去重

  • 数组方法小结

    数组的创建 数组的小方法 常用方法 1、清空一个数组 2、删除数组中的偶数 3、数组去重

  • 数组 定时器

    数组: 面向对象的方式创建: 直接创建: 数组的常用方法: 数组去重: 字符串处理的方法: var a =char...

  • 数组去重

    去重 数组去重常用的方法 1.双循环去重 2.indexOf 去重 3.indexOf()去重 4.利用对象属性去重

  • 前端数组

    数组的常用方法 面向对象的方式创建: 直接创建: 字符串处理的方法: 定时器: 数组去重:

网友评论

      本文标题:最常用数组去重方法

      本文链接:https://www.haomeiwen.com/subject/znnclqtx.html