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

一個(gè)關(guān)于JS正則匹配的踩坑記錄

 更新時(shí)間:2021年04月13日 11:22:42   作者:我叫宋大宗  
這篇文章主要給大家介紹了一個(gè)關(guān)于JS正則匹配的踩坑記錄,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

最近發(fā)現(xiàn)在JS里的正則匹配有一個(gè)坑,而且當(dāng)時(shí)很莫名奇妙,一度讓我懷疑出現(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])
            }
        }

我用正則對(duì)str進(jìn)行全局匹配,當(dāng)滿足的時(shí)候打印出來,于是乎我就得到了這個(gè)

莫名的少了兩個(gè),然后我對(duì)它進(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]))
            }
        }

于是我得到了這個(gè)

又少了一個(gè),但可以看到之前所缺失的兩個(gè)是滿足正則判斷的,然后我在網(wǎng)上找到了下面這段話:

如果在正則匹配中成功匹配到字符串,lastIndex會(huì)被設(shè)置為第一次匹配到的字符串的位置,以作為字符串全局匹配下次檢索的起點(diǎn),如果后面字段還能匹配成功,那么lastIndex會(huì)被反復(fù)重新賦值,直到匹配失敗,它會(huì)被重置為0;

但我去請(qǐng)教了一下我的老師,他告訴我的是匹配到后是將lastIndex+1返回過去,也就是當(dāng)我第一次匹配到后,lastIndex是2,這個(gè)2是字符串里的下標(biāo),而不是數(shù)組的下標(biāo),所以在對(duì)str[1]進(jìn)行判斷時(shí)是從字符串下標(biāo)為2的開始,而不是從0開始,所以第二次判斷為false,這時(shí)匹配失敗,lastIndex被置為0,所以第三次可以匹配成功。

所以在判斷結(jié)果為true后將lastIndex置為0,這樣數(shù)據(jù)就正常了。

數(shù)據(jù)就正常了。

總結(jié)

如果使用全局匹配,那么在每一次查到后將lastIndex置零,或者不使用全局匹配,直接匹配即可。

這里奉上網(wǎng)友的總結(jié):

lastIndex從字面上來講就是最后一個(gè)索引,實(shí)際上它的意思是正則表達(dá)式開始下一次查找的索引位置,第一次的時(shí)候總是為0的,第一次查找完了的時(shí)候會(huì)把lastIndex的值設(shè)為匹配到得字符串的最后一個(gè)字符的索引位置加1,第二次查找的時(shí)候會(huì)從lastIndex這個(gè)位置開始,后面的以此類推。如果沒有找到,則會(huì)把lastIndex重置為0。要注意的是,lastIndex屬性只有在有全局標(biāo)志正則表達(dá)式中才有作用,如果我們把上面代碼中正則表達(dá)式的g標(biāo)志去掉,那么三次彈出的就都是true了。

需要的朋友可以參考下,到此這篇關(guān)于一個(gè)關(guān)于JS正則匹配的踩坑記錄的文章就介紹到這了,更多相關(guān)JS正則匹配踩坑內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • js實(shí)例入門(簡(jiǎn)單展開或關(guān)閉)

    js實(shí)例入門(簡(jiǎn)單展開或關(guān)閉)

    簡(jiǎn)直的展開或關(guān)閉
    2008-11-11
  • Dom加載讓圖片加載完再執(zhí)行的腳本代碼

    Dom加載讓圖片加載完再執(zhí)行的腳本代碼

    當(dāng)大家使用window.onload執(zhí)行一個(gè)函數(shù)時(shí),必須要等到頁面上的圖片等信息全部加載完畢之后才執(zhí)行的。但很多時(shí)候圖片的數(shù)量比較多,所以需要很多時(shí)間下載。更令人尷尬的是,當(dāng)網(wǎng)頁文檔(或者說Dom)已經(jīng)加載完畢,而圖片尚未加載完畢,很多用戶已經(jīng)開始瀏覽網(wǎng)頁,但這時(shí)很多由window.onload所觸發(fā)的函數(shù)不能執(zhí)行,這就導(dǎo)致一部分功能不能完美地給用戶使用,更嚴(yán)重的是會(huì)給用戶留下不好的印象!
    2008-05-05
  • JS+CSS實(shí)現(xiàn)淡入式焦點(diǎn)圖片幻燈切換效果的方法

    JS+CSS實(shí)現(xiàn)淡入式焦點(diǎn)圖片幻燈切換效果的方法

    這篇文章主要介紹了JS+CSS實(shí)現(xiàn)淡入式焦點(diǎn)圖片幻燈切換效果的方法,實(shí)例分析了javascript操作圖片、css等元素實(shí)現(xiàn)幻燈片的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-02-02
  • js實(shí)現(xiàn)漂亮的星空背景

    js實(shí)現(xiàn)漂亮的星空背景

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)漂亮的星空背景,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • Javascript中的async函數(shù)詳解

    Javascript中的async函數(shù)詳解

    這篇文章主要為大家詳細(xì)介紹了Javascript中的async函數(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • 詳解瀏覽器渲染頁面過程

    詳解瀏覽器渲染頁面過程

    這篇文章主要介紹了詳解瀏覽器渲染頁面過程的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • 簡(jiǎn)單了解JavaScript中常見的反模式

    簡(jiǎn)單了解JavaScript中常見的反模式

    這篇文章主要介紹了簡(jiǎn)單了解JavaScript中常見的反模式,反模式 是指對(duì)反復(fù)出現(xiàn)的設(shè)計(jì)問題的常見的無力而低效的設(shè)計(jì)模式,俗話說就是重蹈覆轍。 這篇文章描述了 JavaScript 中常見的一些反模式,以及避免它們的辦法。,需要的朋友可以參考下
    2019-06-06
  • 引用其它js時(shí)如何同時(shí)處理多個(gè)window.onload事件

    引用其它js時(shí)如何同時(shí)處理多個(gè)window.onload事件

    引用其它js時(shí),其js卻使用了window.onload事件,這樣的話,引入的頁面的onload事件就有可能執(zhí)行不了,那么該如何解決呢?祥看下文
    2014-09-09
  • Javascript 遮罩層和加載效果代碼

    Javascript 遮罩層和加載效果代碼

    這篇文章介紹了Javascript 遮罩層和加載效果代碼,有需要的朋友可以參考一下
    2013-08-08
  • 深入理解JavaScript系列(2) 揭秘命名函數(shù)表達(dá)式

    深入理解JavaScript系列(2) 揭秘命名函數(shù)表達(dá)式

    網(wǎng)上還沒用發(fā)現(xiàn)有人對(duì)命名函數(shù)表達(dá)式進(jìn)去重復(fù)深入的討論,正因?yàn)槿绱?,網(wǎng)上出現(xiàn)了各種各樣的誤解,本文將從原理和實(shí)踐兩個(gè)方面來探討JavaScript關(guān)于命名函數(shù)表達(dá)式的優(yōu)缺點(diǎn)
    2012-01-01

最新評(píng)論