您的位置:首页 > Web前端 > JavaScript

js 判断数组是否有重复元素的几种方式

2013-04-18 23:18 671 查看
// 方法一,正则判断

var ary = new Array("111","222","33","112","222");

alert(mm(ary))

// 验证重复元素,有重复返回true;否则返回false

function mm(a) {

    return /(\x0f[^\x0f]+)\x0f[\s\S]*\1/.test("\x0f"+ a.join("\x0f\x0f") +"\x0f");

}

// 方法二,通过数组排序,比较临近元素,可指出重复的元素

var ary = new Array("111","22","33","111","22");

var nary = ary.sort();

for(var i = 0; i < nary.length - 1; i++) {

    if (nary[i] == nary[i+1]) {

        alert("重复内容:" + nary[i]);

    }

}

// 方法三,通过字符串查找

var ary = new Array("111","22","33","111","22");

var s = ary.join(",") + ",";

for(var i = 0; i < ary.length; i++) {

    if(s.replace(ary[i] + ",", "").indexOf(ary[i] + ",") > -1) {

        alert("重复内容:" + ary[i]);

    }

}

// 方法四,通过哈希

var ary = new Array("111","22","33","111","22");

alert(isRepeat(ary));

// 验证重复元素,有重复返回true;否则返回false

function isRepeat(arr) {

    var hash = {};

    for(var i in arr) {

        if(hash[arr[i]]) {

            return true;

        }

        // 不存在该元素,则赋值为true,可以赋任意值,相应的修改if判断条件即可

        hash[arr[i]] = true;

    }

    return false;

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  javascript 数组 正则