您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“如何解決js相同正則多次調(diào)用test()返回的值卻不同的問題”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“如何解決js相同正則多次調(diào)用test()返回的值卻不同的問題”這篇文章吧。
代碼是這樣的:
var reg = /^1[345678][0-9]{9}$/g; console.log(reg.test(15328044636)); console.log(reg.test(15328044636));
會(huì)發(fā)現(xiàn)控制臺(tái)打印的數(shù)據(jù)卻是:
true false
問題原因
這是因?yàn)檎齽treg的g屬性,設(shè)置的全局匹配。RegExp有一個(gè)lastIndex屬性,來保存索引開始位置。
上面的問題,第一次調(diào)用的lastIndex值為0,到了第二次調(diào)用,值變成了11。
var reg = /^1[345678][0-9]{9}$/g; console.log(reg.lastIndex, reg.test(15328044636)); console.log(reg.lastIndex, reg.test(15328044636)); //打印的值 0 true 11 false
解決方案
第一種方案是將g去掉,關(guān)閉全局匹配。
第二種就是在每次匹配之前將lastIndex的值設(shè)置為0。
var reg = /^1[345678][0-9]{9}$/g; console.log(reg.lastIndex, reg.test(15328044636)); reg.lastIndex = 0; console.log(reg.lastIndex, reg.test(15328044636)); //打印的值 0 true 0 true
以上是“如何解決js相同正則多次調(diào)用test()返回的值卻不同的問題”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。