javascript,正则诡异问题,谁能解答
<script type="text/javascript" charset="utf-8">
var button=document.getElementById('btn');
var testReg = new RegExp("(?=.{6,}).*","g");
//点击按钮开始匹配
button.onclick=function(){
console.log(testReg.test("abcdefg")); //这个值都没变,为什么匹配的结果一true一false,值都没变啊,要不都是true,要不都是false啊,求高手解答诡异问题
}
</script> 展开
用RegExp.test() 找到后,它会以 lastIndex 属性所指的位置作为下次检索的起始点。这样,就可以通过反复调用这两个方法来遍历一个字符串中的所有匹配文本。
该属性是可读可写的。只要目标字符串的下一次搜索开始,就可以对它进行设置。当方法 test() 再也找不到可以匹配的文本时,它们会自动把 lastIndex 属性重置为 0。
<input type="button" id="btn" value="按钮" />
<script type="text/javascript" charset="utf-8">
var button=document.getElementById('btn');
var testReg = new RegExp("(?=.{6,}).*","g");
//点击按钮开始匹配
button.onclick=function(){
testReg.lastIndex = 0; //或者可以手动重置它
console.log(testReg.test("abcdefg"));
}
</script>
重要事项:不具有标志 g 和不表示全局模式的 RegExp 对象不能使用 lastIndex 属性。
提示:如果在成功地匹配了某个字符串之后就开始检索另一个新的字符串,需要手动地把这个属性设置为 0。
JavaScript里正则表达式对象 RegExp 的 test 方法,是用来检查 字符串是否存在自己定义的正则模式,并返回一个boolean值,也就是 如果有匹配的模式,返回 true,没有,则返回 false
(?=pattern)——正向预查
发生匹配后,下一匹配的搜索紧随上一匹配之后,不包含预查字符
你的testReg正则对象是一个全局的。lastIndex 属性被 RegExp 对象的 exec 和 test 方法,以及 String 对象的 match、replace、和 split 方法修改,lastIndex 属性是基于零的,产生一个成功匹配,它的值都被修改,lastIndex 被设置为紧接最后的匹配的下一个位置。lastIndex只适用于全局RegExp对象