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, "我", "我的"]    
    

      

  • 相关阅读:
    轻配置 Vim
    PHP 使用 wkhtmltopdf/image 把HTML页面转换成 PDF/image 文件
    使用 Mailgun 实现 带附件的Email 发送功能
    LinkedIn 第三方登录(JavaScript SDK)
    react学习2
    前端面试题
    react学习
    前端面试-字符串-逆序-间隔
    前端文件上传相关知识
    js原型prototype问题
  • 原文地址:https://www.cnblogs.com/ghfjj/p/6660339.html
Copyright © 2011-2022 走看看