詳談lastIndex對(duì)正則結(jié)果的影響
前言
今天遇到一個(gè)問(wèn)題,用正則表達(dá)式去檢查同一個(gè)字符串時(shí),交替返回true和false。無(wú)奈之下,重新翻了翻權(quán)威指南,發(fā)現(xiàn)罪魁禍?zhǔn)自瓉?lái)是lastIndex。可在控制臺(tái)嘗試下
let reg = /[\d]/g //undefined reg.test(1) //true reg.test(1) //false
lastIndex
lastIndex在權(quán)威指南中是如下解釋:它是一個(gè)可讀/寫的整數(shù)。如果匹配模式帶有g(shù)修飾符,這個(gè)屬性存儲(chǔ)在整個(gè)字符串中下次索引的開(kāi)始位置,這個(gè)屬性會(huì)被exec()和test()用到。還是上面的例子,觀察下lastIndex屬性
let reg = /[\d]/g //有修飾符g //undefined reg.lastIndex //0 reg.test(1) //true reg.lastIndex //匹配一次后,lastIndex改變 //1 reg.test(1) //從index 1 開(kāi)始匹配 //false reg.lastIndex //0 reg.test(1) //true reg.lastIndex //1
第一次使用test()匹配成功后,lastIndex被設(shè)為匹配到的結(jié)束位置,就是1;第二次再test()時(shí),從index 1 開(kāi)始匹配,匹配失敗,lastIndex重置為0 。這樣就造成了匹配結(jié)果與預(yù)期不符
解決
1、不使用 g 修飾符
reg = /[\d]/ ///[\d]/ reg.test(1) //true reg.test(1) //true reg.lastIndex //0 reg.test(1) //true reg.lastIndex
2、test()之后手動(dòng)設(shè)置lastIndex = 0
以上這篇詳談lastIndex對(duì)正則結(jié)果的影響就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
javascript中10個(gè)正則表達(dá)式使用介紹基礎(chǔ)篇
本文通過(guò)舉例簡(jiǎn)單的介紹了正則表達(dá)式的一些使用方法,能夠助力你快速入門正則表達(dá)式,希望這篇正則總結(jié)方法能對(duì)你有用2020-02-02
JavaScript正則表達(dá)式校驗(yàn)非正整數(shù)實(shí)例
本文分享了js正則表達(dá)式(^((-\d+)|(0+))$)校驗(yàn)非正整數(shù)實(shí)例代碼,代碼簡(jiǎn)單易懂,需要的朋友可以看下2016-12-12
正則表達(dá)式 匹配至少有一個(gè)非空白字符并且不超過(guò)指定長(zhǎng)度
最近需要用到一個(gè)驗(yàn)證,規(guī)則為:至少有一個(gè)非空白字符并且不超過(guò)指定長(zhǎng)度,想用正則表達(dá)式來(lái)處理,上網(wǎng)搜了一下,發(fā)現(xiàn)其他人也有和我一樣的需求,并且有高手給了幾個(gè)很精彩的解決方案,現(xiàn)將網(wǎng)上的解決方案整理一下,以備其他有相同需求的人參考2011-11-11
正則表達(dá)式在IOS中的應(yīng)用及IOS中三種正則表達(dá)式的使用與比較
本篇文章給大家介紹正則表達(dá)式在IOS中應(yīng)用以及IOS中三種正則表達(dá)式式的使用與比較,感興趣的朋友跟著小編一起來(lái)學(xué)習(xí)學(xué)習(xí)吧2015-09-09

