前言
一般,我們可能會(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字符串中包含過個(gè)A字符串呢?
方法一 indexOf() 和 lastIndexOf() 對(duì)比法.
首先,我們構(gòu)建代碼:
var arr = ["aa","bb","cc","bb","aa"];arrRepeat(arr);
如上,我們要用一個(gè)arrRepeat(arr)的校驗(yàn)函數(shù)并執(zhí)行,下面來構(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)行成功.
原理特別簡(jiǎn)單,就是,數(shù)組中的字段,在由數(shù)組變成的字符串中的首次出現(xiàn)位置和最后一次出現(xiàn)位置是否一致,如果不一致,就說明這個(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)行又一次成功
總結(jié)
如果僅僅是比對(duì)第一個(gè)方法其實(shí)足夠用了.
第二個(gè)方法可以查找出現(xiàn)的真實(shí)次數(shù),比如重復(fù)了4次,就能找到4.具體的用途自己思考咯.
構(gòu)建包含變量的正則的方法new RegExp(arr[i],"g")也是問別人才問出來的.
其實(shí)我先想到的是第二個(gè)思路,正則的問題困擾半天,終于解決了.才想到第一個(gè)思路的.
以上所述是小編給大家介紹的JavaScript判斷數(shù)組重復(fù)內(nèi)容的兩種方法(推薦),希望能夠幫助到大家!
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注