一個關(guān)于JS正則匹配的踩坑記錄
最近發(fā)現(xiàn)在JS里的正則匹配有一個坑,而且當(dāng)時很莫名奇妙,一度讓我懷疑出現(xiàn)了靈異事件。
下面是踩坑代碼
var str=["二七1","二七2","金水","二七3","二七4","二七5"] var reg=new RegExp("二七","g"); for(var i=0;i<str.length;i++){ if(reg.test(str[i])){ console.log(str[i]) } }
我用正則對str進(jìn)行全局匹配,當(dāng)滿足的時候打印出來,于是乎我就得到了這個
莫名的少了兩個,然后我對它進(jìn)行單獨(dú)的判斷
var str=["二七1","二七2","金水","二七3","二七4","二七5"] var reg=new RegExp("二七","g"); for(var i=0;i<str.length;i++){ if(reg.test(str[i])){ console.log(str[i]) } if(i==1){ console.log(reg.test(str[i])) } if(i==4){ console.log(reg.test(str[i])) } }
于是我得到了這個
又少了一個,但可以看到之前所缺失的兩個是滿足正則判斷的,然后我在網(wǎng)上找到了下面這段話:
如果在正則匹配中成功匹配到字符串,lastIndex會被設(shè)置為第一次匹配到的字符串的位置,以作為字符串全局匹配下次檢索的起點(diǎn),如果后面字段還能匹配成功,那么lastIndex會被反復(fù)重新賦值,直到匹配失敗,它會被重置為0;
但我去請教了一下我的老師,他告訴我的是匹配到后是將lastIndex+1返回過去,也就是當(dāng)我第一次匹配到后,lastIndex是2,這個2是字符串里的下標(biāo),而不是數(shù)組的下標(biāo),所以在對str[1]進(jìn)行判斷時是從字符串下標(biāo)為2的開始,而不是從0開始,所以第二次判斷為false,這時匹配失敗,lastIndex被置為0,所以第三次可以匹配成功。
所以在判斷結(jié)果為true后將lastIndex置為0,這樣數(shù)據(jù)就正常了。
數(shù)據(jù)就正常了。
總結(jié)
如果使用全局匹配,那么在每一次查到后將lastIndex置零,或者不使用全局匹配,直接匹配即可。
這里奉上網(wǎng)友的總結(jié):
lastIndex從字面上來講就是最后一個索引,實(shí)際上它的意思是正則表達(dá)式開始下一次查找的索引位置,第一次的時候總是為0的,第一次查找完了的時候會把lastIndex的值設(shè)為匹配到得字符串的最后一個字符的索引位置加1,第二次查找的時候會從lastIndex這個位置開始,后面的以此類推。如果沒有找到,則會把lastIndex重置為0。要注意的是,lastIndex屬性只有在有全局標(biāo)志正則表達(dá)式中才有作用,如果我們把上面代碼中正則表達(dá)式的g標(biāo)志去掉,那么三次彈出的就都是true了。
需要的朋友可以參考下,到此這篇關(guān)于一個關(guān)于JS正則匹配的踩坑記錄的文章就介紹到這了,更多相關(guān)JS正則匹配踩坑內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS+CSS實(shí)現(xiàn)淡入式焦點(diǎn)圖片幻燈切換效果的方法
這篇文章主要介紹了JS+CSS實(shí)現(xiàn)淡入式焦點(diǎn)圖片幻燈切換效果的方法,實(shí)例分析了javascript操作圖片、css等元素實(shí)現(xiàn)幻燈片的技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-02-02引用其它js時如何同時處理多個window.onload事件
引用其它js時,其js卻使用了window.onload事件,這樣的話,引入的頁面的onload事件就有可能執(zhí)行不了,那么該如何解決呢?祥看下文2014-09-09深入理解JavaScript系列(2) 揭秘命名函數(shù)表達(dá)式
網(wǎng)上還沒用發(fā)現(xiàn)有人對命名函數(shù)表達(dá)式進(jìn)去重復(fù)深入的討論,正因?yàn)槿绱?,網(wǎng)上出現(xiàn)了各種各樣的誤解,本文將從原理和實(shí)踐兩個方面來探討JavaScript關(guān)于命名函數(shù)表達(dá)式的優(yōu)缺點(diǎn)2012-01-01