js判断数组里是否有重复元素的方法
生活随笔
收集整理的這篇文章主要介紹了
js判断数组里是否有重复元素的方法
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
轉(zhuǎn):
js判斷數(shù)組里是否有重復(fù)元素的方法
?https://blog.csdn.net/longzhoufeng/article/details/78840974第一種方法:但是下面的這種方法數(shù)字字符串類(lèi)似相同,返回的還是真,有點(diǎn)不靠譜,如果是其它的字符是可以的
var ary11 = new Array("1", "ff", "11", "aa", "2222"); // 驗(yàn)證重復(fù)元素,有重復(fù)返回true;否則返回false function mm(a) {return /(\x0f[^\x0f]+)\x0f[\s\S]*\1/.test("\x0f" + a.join("\x0f\x0f") + "\x0f"); }mm(ary11)alert(mm(ary11))?
第二種方法:但是下面的這種方法數(shù)字字符串類(lèi)似相同,返回的也還是真,有點(diǎn)不靠譜,如果是其它的字符是可以的
var ary = ["1", "ff", "11", "aa", "2222"] var s = ary.join(",") + ","; for(var i = 0; i < ary.length; i++) {if(s.replace(ary[i] + ",", "").indexOf(ary[i] + ",") > -1) {alert("數(shù)組中有重復(fù)元素:" + ary[i]);break;} }?
第三種方法:這種方法好像不會(huì)有什么問(wèn)題
var ary = new Array("11", "222", "33", "111", "22"); var nary = ary.sort(); for(var i = 0; i < nary.length - 1; i++) {if(nary[i] == nary[i + 1]) {alert("重復(fù)內(nèi)容:" + nary[i]);} }?
第四種方法:這種方法好像不會(huì)有什么問(wèn)題
var ary = new Array("1111", "222", "33", "111", "22"); alert(isRepeat(ary)); // 驗(yàn)證重復(fù)元素,有重復(fù)返回true;否則返回false function isRepeat(arr) {var hash = {};for(var i in arr) {if(hash[arr[i]]) {return true;}// 不存在該元素,則賦值為true,可以賦任意值,相應(yīng)的修改if判斷條件即可hash[arr[i]] = true;}return false; }?
?轉(zhuǎn)載于:https://www.cnblogs.com/libin6505/p/10361681.html
總結(jié)
以上是生活随笔為你收集整理的js判断数组里是否有重复元素的方法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Python网络编程之socket编程
- 下一篇: 第一个程序 快速编译链接的办法