欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript判斷數(shù)組重復(fù)內(nèi)容的兩種方法(推薦)

 更新時(shí)間:2016年06月06日 17:11:00   作者:FungLeo  
本文給大家介紹兩種JavaScript判斷數(shù)組重復(fù)內(nèi)容的方法(推薦)非常不錯(cuò)具有參考借鑒價(jià)值,感興趣的朋友一起看看吧

前言

一般,我們可能會(huì)給數(shù)組去重,這個(gè)操作并不復(fù)雜,執(zhí)行一個(gè)循環(huán)就是了.現(xiàn)在,我要做的是,判斷數(shù)組中是否有重復(fù)的內(nèi)容,如果有,返回 true 否則,返回 false.

思路

把數(shù)組變成字符串

循環(huán)原數(shù)組,拿每一個(gè)字段和這個(gè)字符串進(jìn)行比對(duì),看是否有重復(fù)

如何拿A字符串和B字符串進(jìn)行對(duì)比,并且要求判斷出B字符串中包含過(guò)個(gè)A字符串呢?

方法一 indexOf() 和 lastIndexOf() 對(duì)比法.

首先,我們構(gòu)建代碼:

var arr = ["aa","bb","cc","bb","aa"];
arrRepeat(arr);

如上,我們要用一個(gè)arrRepeat(arr)的校驗(yàn)函數(shù)并執(zhí)行,下面來(lái)構(gòu)建這個(gè)函數(shù)

function arrRepeat(arr){
var arrStr = JSON.stringify(arr),str;
for (var i = 0; i < arr.length; i++) {
if (arrStr.indexOf(arr[i]) != arrStr.lastIndexOf(arr[i])){
return true;
}
};
return false;
}

OK,運(yùn)行成功.

運(yùn)行結(jié)果

原理特別簡(jiǎn)單,就是,數(shù)組中的字段,在由數(shù)組變成的字符串中的首次出現(xiàn)位置和最后一次出現(xiàn)位置是否一致,如果不一致,就說(shuō)明這個(gè)重復(fù)出現(xiàn)了.

方法二 match() 正則對(duì)比方法

首先,和上面一樣,我們構(gòu)建代碼:

var arr = ["aa","bb","cc","bb","aa"];
arrRepeat(arr);

然后,我們重新構(gòu)建arrRepeat(arr)函數(shù)

function arrRepeat(arr){
var arrStr = JSON.stringify(arr),str;
for (var i = 0; i < arr.length; i++) {
if ((arrStr.match(new RegExp(arr[i],"g")).length)>1){
return true;
}
};
return false;
}

原理是查找確定的重復(fù)次數(shù),如果是大于1的話,就肯定是重復(fù)了.注意,這里是能夠準(zhǔn)確的查找出出現(xiàn)了幾次的哦!所以,這個(gè)方法其實(shí)有更廣泛的用途.

OK,運(yùn)行又一次成功

運(yùn)行結(jié)果二

總結(jié)

如果僅僅是比對(duì)第一個(gè)方法其實(shí)足夠用了.

第二個(gè)方法可以查找出現(xiàn)的真實(shí)次數(shù),比如重復(fù)了4次,就能找到4.具體的用途自己思考咯.

構(gòu)建包含變量的正則的方法new RegExp(arr[i],"g")也是問(wèn)別人才問(wèn)出來(lái)的.

其實(shí)我先想到的是第二個(gè)思路,正則的問(wèn)題困擾半天,終于解決了.才想到第一個(gè)思路的.

以上所述是小編給大家介紹的JavaScript判斷數(shù)組重復(fù)內(nèi)容的兩種方法(推薦),希望能夠幫助到大家!

相關(guān)文章

最新評(píng)論