前言
今天遇到一個問題,用正則表達(dá)式去檢查同一個字符串時,交替返回true和false。無奈之下,重新翻了翻權(quán)威指南,發(fā)現(xiàn)罪魁禍?zhǔn)自瓉硎莑astIndex??稍诳刂婆_嘗試下
let reg = /[\d]/g
//undefined
reg.test(1)
//true
reg.test(1)
//false
lastIndex
lastIndex在權(quán)威指南中是如下解釋:它是一個可讀/寫的整數(shù)。如果匹配模式帶有g(shù)修飾符,這個屬性存儲在整個字符串中下次索引的開始位置,這個屬性會被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 開始匹配
//false
reg.lastIndex
//0
reg.test(1)
//true
reg.lastIndex
//1
第一次使用test()匹配成功后,lastIndex被設(shè)為匹配到的結(jié)束位置,就是1;第二次再test()時,從index 1 開始匹配,匹配失敗,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()之后手動設(shè)置lastIndex = 0
以上這篇詳談lastIndex對正則結(jié)果的影響就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:- 淺析正則表達(dá)式中的lastIndex以及預(yù)查
- JS中正則表達(dá)式要注意lastIndex屬性
- Javascript lastIndex 正則表達(dá)式的一個疑惑