一个关于JS正则匹配的踩坑记录

最近发此刻JS里的正则匹配有一个坑,并且其时很莫名奇妙,一度让我猜疑呈现了灵异事件。

下面是踩坑代码

var str=["二七1","二七2","金水","二七3","二七4","二七5"] var reg=new RegExp("二七","g"); for(var i=0;i<str.length;i++){ if(reg.test(str[i])){ console.log(str[i]) } }

我用正则对str举办全局匹配,当满意的时候打印出来,于是乎我就获得了这个

一个关于JS正则匹配的踩坑记录

莫名的少了两个,然后我对它举办单独的判定

var str=["二七1","二七2","金水","二七3","二七4","二七5"] var reg=new RegExp("二七","g"); for(var i=0;i<str.length;i++){ if(reg.test(str[i])){ console.log(str[i]) } if(i==1){ console.log(reg.test(str[i])) } if(i==4){ console.log(reg.test(str[i])) } }

于是我获得了这个

一个关于JS正则匹配的踩坑记录

又少了一个,但可以看到之前所缺失的两个是满意正则判定的,然后我在网上找到了下面这段话:

假如在正则匹配中乐成匹配到字符串,lastIndex会被配置为第一次匹配到的字符串的位置,以作为字符串全局匹配下次检索的起点,假如后头字段还能匹配乐成,那么lastIndex会被重复从头赋值,直到匹配失败,它会被重置为0;

但我去请教了一下我的老师,他汇报我的是匹配到后是将lastIndex+1返回已往,也就是当我第一次匹配到后,lastIndex是2,这个2是字符串里的下标,而不是数组的下标,所以在对str[1]举办判定时是从字符串下标为2的开始,而不是从0开始,所以第二次判定为false,这时匹配失败,lastIndex被置为0,所以第三次可以匹配乐成。

所以在判定功效为true后将lastIndex置为0,这样数据就正常了。

一个关于JS正则匹配的踩坑记录

数据就正常了。

总结

假如利用全局匹配,那么在每一次查到后将lastIndex置零,可能不利用全局匹配,直接匹配即可。

这里送上网友的总结:

lastIndex从字面上来讲就是最后一个索引,实际上它的意思是正则表达式开始下一次查找的索引位置,第一次的时候老是为0的,第一次查找完了的时候会把lastIndex的值设为匹配到得字符串的最后一个字符的索引位置加1,第二次查找的时候会从lastIndex这个位置开始,后头的以此类推。假如没有找到,则会把lastIndex重置为0。要留意的是,lastIndex属性只有在有全局符号正则表达式中才有浸染,假如我们把上面代码中正则表达式的g符号去掉,那么三次弹出的就都是true了。

需要的伴侣可以参考下,到此这篇关于一个关于JS正则匹配的踩坑记录的文章就先容到这了,更多相关JS正则匹配踩坑内容请搜索剧本之家以前的文章或继承欣赏下面的相关文章但愿各人今后多多支持剧本之家!

您大概感乐趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wsjfjp.html