重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要为大家展示了“如何解决js相同正则多次调用test()返回的值却不同的问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决js相同正则多次调用test()返回的值却不同的问题”这篇文章吧。
创新互联主营沭阳网站建设的网络公司,主营网站建设方案,app开发定制,沭阳h5小程序开发搭建,沭阳网站营销推广欢迎沭阳等地区企业咨询
代码是这样的:
var reg = /^1[345678][0-9]{9}$/g; console.log(reg.test(15328044636)); console.log(reg.test(15328044636));
会发现控制台打印的数据却是:
true false
问题原因
这是因为正则reg的g属性,设置的全局匹配。RegExp有一个lastIndex属性,来保存索引开始位置。
上面的问题,第一次调用的lastIndex值为0,到了第二次调用,值变成了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去掉,关闭全局匹配。
第二种就是在每次匹配之前将lastIndex的值设置为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相同正则多次调用test()返回的值却不同的问题”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!