這篇文章主要為大家展示了“如何解決js相同正則多次調(diào)用test()返回的值卻不同的問(wèn)題”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“如何解決js相同正則多次調(diào)用test()返回的值卻不同的問(wèn)題”這篇文章吧。
創(chuàng)新互聯(lián)主營(yíng)沭陽(yáng)網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,app開(kāi)發(fā)定制,沭陽(yáng)h5小程序開(kāi)發(fā)搭建,沭陽(yáng)網(wǎng)站營(yíng)銷推廣歡迎沭陽(yáng)等地區(qū)企業(yè)咨詢
代碼是這樣的:
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
問(wèn)題原因
這是因?yàn)檎齽treg的g屬性,設(shè)置的全局匹配。RegExp有一個(gè)lastIndex屬性,來(lái)保存索引開(kāi)始位置。
上面的問(wèn)題,第一次調(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()返回的值卻不同的問(wèn)題”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!