zoukankan      html  css  js  c++  java
  • js数组去重的四种方法

    //第一种方法
    Array.prototype.removeDuplicate = function() {
        var n = [];
        for (var i = 0; i < this.length; i++) {
            if (n.indexOf(this[i]) == -1) {
                n.push(this[i]);
            }
        }
        return n;
    }
    var arr = [1, 2, 3, 3, 2, '我', '我', 34, '我', NaN, NaN];
    var m1 = arr.removeDuplicate();
    console.log(m1); //[1, 2, 3, "我", 34, "我的", NaN, NaN]
    document.write("第一种方法<br>");
    document.write("数组值:"+arr + "<br>");
    document.write("删除重复后:"+m1);
    //第二种方法
    Array.prototype.removeDuplicate = function() {
        var n = [];
        for (var i = 0; i < this.length - 1; i++) {
            if (this.indexOf(this[i]) == i) {
                n.push(this[i]);
            }
        }
        return n;
    }
    var m2 = arr.removeDuplicate();
    console.log(m2); //[1, 2, 3, "我", 34, "我的"]
    //第三种方法
    Array.prototype.removeDuplicate = function() {
        var n = [],
        m = {};
        for (var i = 0; i < this.length; i++) {
            if (!m[this[i]]) {
                m[this[i]] = true;
                n.push(this[i]);
            }
        }
        return n;
    }
    var m3 = arr.removeDuplicate();
    console.log(m3); //[1, 2, 3, "我", 34, "我的", NaN]
    //第四种方法
    Array.prototype.removeDuplicate = function() {
        var n = [];
        this.sort();
        for (var i = 0; i < this.length; i++) {
            if (this[i] != this[i + 1]) {
                n.push(this[i]);
            }
        }
        return n;
    }
    var m4 = arr.removeDuplicate();
    console.log(m4); //[1, 2, 3, 34, NaN, NaN, "我", "我的"]    
    

      

  • 相关阅读:
    WebService是什么?以及工作原理
    分布锁的问题?
    反射是什么?原理?作用?
    HTTP/1.1与HTTP/1.0的区别
    Ajax的跨域问题(包括解决方案)?
    SVN与Git优缺点比较
    类的加载过程?
    B树, B-树,B+树,和B*树的区别
    Linux常用的50个命令
    权限模型
  • 原文地址:https://www.cnblogs.com/ghfjj/p/6660339.html
Copyright © 2011-2022 走看看