正则的一个坑

 test()方法慎用g
test()检测指定字符串是否存在返回一个布尔值

var  reg=/cat/g;
var str='this a cat,this a dog'; 
console.log(reg.test(str),reg.lastIndex);//true 10
console.log(reg.test(str),reg.lastIndex); //false 0

 

按道理两次打印出来都应该是true,true,而最终结果为true,false。
此时我们需要注意啦,在我们定义的正则表达式中后面加上了搜索的方式,g表示全文查找。而且在正则表达式内部有一个lastIndex来记录匹配的位置,第一次调用test()后,那么lastIndex就不再等于0,而是10,当下次在调用该方法的时候,字符串的匹配会从lastIndex位置进行匹配,故最终返回false.所以不要随意添加g.
遇到此种情况后的解决方法:
1.去除g;
2.在第二次使用前,设置reg.lastIndex=0即可。

3.加个判断,判断当前输入框内容和上一次匹配的内容是否一样,如果一样就不匹配了

不一样才匹配

 

哪么正则加g和不加g有什么区别楞

1,g记录成功的lastIndex  下次支配同一个字符串就直接从记录的lastIndex位置开始

而不是从头开始了

2、如果你不带g,在正则过程中,字符串是从左至右匹配的,如果匹配成功就不再继续向右匹配了,如果你带g,它会重头到尾的把正确匹配的字符串挑选出来

var str = 'aaaaaaaa'
var reg1 = /a/
var reg2 = /a/g
str.match(reg1)  // 结果为:["a", index: 0, input: "aaaaaaaa"]
str.match(reg2)  // 结果为:["a", "a", "a", "a", "a", "a", "a", "a"]

 

posted @ 2018-07-06 09:50  刘雄辉  阅读(187)  评论(0编辑  收藏  举报