• js数组去重的4种方法


    js数组去重,老生长谈,今天对其进行一番归纳,总结出来4种方法

    贴入代码前 ,先对浏览器Array对象进行支持indexOf和forEach的polyfill

    Array.prototype.indexOf = Array.prototype.indexOf || function(item) {
        for (var i = 0, j = this.length; i < j; i++) {
            if (this[i] === item) {
                return i;
            }
        }
        return -1;
    }
    
    Array.prototype.forEach = Array.prototype.forEach || function(callback, thisArg) {
        if (!callback || typeof callback !== 'function') return;
    
        for (var i = 0, j = this.length; i < j; i++) {
            callback.call(thisArg, this[i], i, this);
        }
    }

    方法一:遍历数组,建立新数组,利用indexOf判断是否存在于新数组中,不存在则push到新数组,最后返回新数组

     1 function removeDuplicatedItem(ar) {
     2     var ret = [];
     3 
     4     for (var i = 0, j = ar.length; i < j; i++) {
     5         if (ret.indexOf(ar[i]) === -1) {
     6             ret.push(ar[i]);
     7         }
     8     }
     9 
    10     return ret;
    11 }

    方法二:遍历数组,利用object对象保存数组值,判断数组值是否已经保存在object中,未保存则push到新数组并用object[arrayItem]=1的方式记录保存

    function removeDuplicatedItem2(ar) {
        var tmp = {},
            ret = [];
    
        for (var i = 0, j = ar.length; i < j; i++) {
            if (!tmp[ar[i]]) {
                tmp[ar[i]] = 1;
                ret.push(ar[i]);
            }
        }
    
        return ret;
    }

    方法三:数组下标判断法, 遍历数组,利用indexOf判断元素的值是否与当前索引相等,如相等则加入

    function removeDuplicatedItem3(ar) {
        var ret = [];
    
        ar.forEach(function(e, i, ar) {
            if (ar.indexOf(e) === i) {
                ret.push(e);
            }
        });
    
        return ret;
    }

    方法四:数组先排序, 然后比较俩数组一头一尾进行去重

    function removeDuplicatedItem4(ar) {
        var ret = [],
            end;
        ar.sort();
        end = ar[0];
        ret.push(ar[0]);
    
        for (var i = 1; i < ar.length; i++) {
            if (ar[i] != end) {
                ret.push(ar[i]);
                end = ar[i];
            }
        }
    
        return ret;
    }

     有其他好的方式 ,欢迎补充。

  • 相关阅读:
    线性回归 r python 比较
    vps
    插桩 inline hook 动态二进制插桩的原理和基本实现过程
    duration of lease 1 0.5 0.875 DHCP 租借时间 续租时间 重新绑定时间
    单页应用 cookies处理
    websocket 无需通过轮询服务器的方式以获得响应 同步在线用户数 上线下线 抓包 3-way-handshake web-linux-shell 开发
    code_action
    mysql 表级锁
    mysql 表级锁
    块级标签和行级标签
  • 原文地址:https://www.cnblogs.com/leonwang/p/4845576.html
Copyright © 2020-2023  润新知