js数组去重

简介: js数组去重的几种方法

1.双重循环
每次插入一个元素的时候都和前面的每个元素比较一下

var array = [1, 1, '1', '1'];
function unique(array) {
    // res用来存储结果
    var res = [];
    for (var i = 0, arrayLen = array.length; i < arrayLen; i++) {
        for (var j = 0, resLen = res.length; j < resLen; j++ ) {
            if (array[i] === res[j]) {
                break;
            }
        }
        // 如果array[i]是唯一的,那么执行完循环,j等于resLen
        if (j === resLen) {
            res.push(array[i])
        }
    }
    return res;
}

console.log(unique(array)); // [1, "1"]

2.indexOf
原理和双重循环是一样的

var array = [1, 1, '1'];

function unique(array) {
    var res = [];
    for (var i = 0, len = array.length; i < len; i++) {
        var current = array[i];
        if (res.indexOf(current) === -1) {
            res.push(current)
        }
    }
    return res;
}

console.log(unique(array));

3.排序后去重
对于排好序的数组,可以将每个元素与前一个比较

var array = [1, 1, '1'];

function unique(array) {
    var res = [];
    var sortedArray = array.concat().sort();
    var seen;
    for (var i = 0, len = sortedArray.length; i < len; i++) {
        // 如果是第一个元素或者相邻的元素不相同
        if (!i || seen !== sortedArray[i]) {
            res.push(sortedArray[i])
        }
        seen = sortedArray[i];
    }
    return res;
}

console.log(unique(array));

4.Object 键值对
把每一个元素存成 object 的 key。例如 ['a'],存成{'a': true}

var array = [1, 2, 1, 1, '1'];
function unique(array) {
    var obj = {};
    return array.filter(function(item, index, array){
        return obj.hasOwnProperty(item) ? false : (obj[item] = true)
    })
}
console.log(unique(array)); // [1, 2]

我们可以发现,是有问题的,因为 1 和 '1' 是不同的,但是这种方法会判断为同一个值,这是因为对象的键值只能是字符串,所以我们可以使用 typeof item + item 拼成字符串作为 key 值来避免这个问题:

var array = [1, 2, 1, 1, '1'];
function unique(array) {
    var obj = {};
    return array.filter(function(item, index, array){
        return obj.hasOwnProperty(typeof item + item) ? false : (obj[typeof item + item] = true)
    })
}
console.log(unique(array)); // [1, 2, "1"]

然而,即便如此,我们依然无法正确区分出两个对象,比如 {value: 1} 和 {value: 2},因为typeof item + item 的结果都会是 object[object Object],不过我们可以使用 JSON.stringify 将对象序列化:

var array = [{value: 1}, {value: 1}, {value: 2}];
function unique(array) {
    var obj = {};
    return array.filter(function(item, index, array){
        console.log(typeof item + JSON.stringify(item))
        return obj.hasOwnProperty(typeof item + JSON.stringify(item)) ? false : (obj[typeof item + JSON.stringify(item)] = true)
    })
}

console.log(unique(array)); // [{value: 1}, {value: 2}]

5.ES6 Set去重

function unique(array) {
   return Array.from(new Set(array));
}
function unique(array) {
    return [...new Set(array)];
}

6.ES6 Map

function unique (arr) {
    const seen = new Map()
    return arr.filter((a) => !seen.has(a) && seen.set(a, 1))
}
相关文章
|
3月前
|
JavaScript 小程序
js数组去重的10种有效方法 vue 数组去重
js数组去重的10种有效方法 vue 数组去重
|
5月前
|
JavaScript 算法
JS数组去重的6种算法实现
JS数组去重的6种算法实现
32 0
|
7月前
|
存储 JavaScript 前端开发
JavaScript 数组去重大揭秘:高手必备技巧一网打尽!
数组去重是在 JavaScript 开发中经常遇到的问题。本文将从前言、分析、使用场景、具体实现代码和注意事项等方面,详细讨论 JavaScript 数组去重的方法。
76 1
 JavaScript 数组去重大揭秘:高手必备技巧一网打尽!
|
3月前
|
JavaScript 前端开发
js实现对象数组去重(背,新人友好)
js实现对象数组去重(背,新人友好)
27 0
|
3月前
|
JavaScript 前端开发 索引
【面试题】Js数组去重都有哪些方法?
【面试题】Js数组去重都有哪些方法?
|
3月前
|
JavaScript
js数组去重排序
js数组去重排序
|
4月前
|
JavaScript 前端开发
JavaScript数组去重,大小排序的两种方法
JavaScript数组去重,大小排序的两种方法
|
4月前
|
存储 JavaScript 前端开发
js的数组去重方法
js的数组去重方法
42 0
|
4月前
|
JavaScript 前端开发
js中数组去重
js中数组去重
20 0
|
4月前
|
JavaScript
JS 数组去重
JS 数组去重