前言
今天遇到一個(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è)可讀/寫(xiě)的整數(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è)參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:- 淺析正則表達(dá)式中的lastIndex以及預(yù)查
- JS中正則表達(dá)式要注意lastIndex屬性
- Javascript lastIndex 正則表達(dá)式的一個(gè)疑惑