美文网首页
数组去重的几个方法

数组去重的几个方法

作者: _theFeng | 来源:发表于2019-03-20 18:00 被阅读0次

    双循环

    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"]
    

    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));
    

    filter

    var array = [1, 2, 1, 1, '1'];
    
    function unique(array) {
        var res = array.filter(function(item, index, array){
            return array.indexOf(item) === index;
        })
        return res;
    }
    
    console.log(unique(array));
    

    Object

    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]
    

    es6

    var array = [1, 2, 1, 1, '1'];
    
    function unique(array) {
       return Array.from(new Set(array));
    }
    
    console.log(unique(array)); // [1, 2, "1"]
    
    var unique = (a) => [...new Set(a)]
    
    function unique (arr) {
        const seen = new Map()
        return arr.filter((a) => !seen.has(a) && seen.set(a, 1))
    }
    

    相关文章

      网友评论

          本文标题:数组去重的几个方法

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