javascript的test方法的“陷阱”
2014-03-15 15:53
155 查看
<script type="text/javascript">
<!--
var re = /[a]/g;
alert(re.test('a'));
//-->
</script>
弹出:ture
上面的正则表达式的作用是匹配字幕‘a’,运行起来也没有任何问题。
上面的代码的确没有问题不过,当re.test再次被执行时,bug就出来了。如下:
<script type="text/javascript">
<!--
var re = /[a]/g;
alert(re.test('a'));
alert(re.test('a'));
//-->
</script>
弹出:ture false
相同的语句执行两次后,解决居然不一样。faint。搞了很久,又发帖问高手,得知问题在于这个“g” flag上面。
去掉re的g标识,一切又正常了。
从梅雪花大哥那里得知如果test使用“g”标识,那么re.lastIndex属性将生效,lastIndex属性将记录上次test成功的index。
如第一次执行test后为ture,lastIndex值设置为1,也就是说它跨过了索引0(“a”),当再次执行test的时候,也将使用lastIndex作为起始索引。这样当然就找不到“a”了。
如果去掉“g”标识,lastIndex属性就无效了。虽然它的lastIndex也改变,但不影响test方法结果。
修正后的代码:
<script type="text/javascript">
<!--
var re = /[a]/;
alert(re.test('a'));
alert(re.test('a'));
//-->
</script>
相关文章推荐
- javascript的test方法的“陷阱”/*g引起的*/
- javascript的test方法的“陷阱”
- javascript的test方法的“陷阱”
- javascript中Uint8Array类型的subarray方法陷阱
- JavaScript中的继承学习笔记(1):Crockford uber方法中的陷阱
- javascript正则全局匹配g慎用test方法
- <a href="javascript:;" onclick="f1();" >test</a>单击不起作用的解决方法
- javascript中RegExp对象的test方法
- JavaScript中的test()方法
- 【JavaScript】javascript 方法 test()
- JavaScript 正则表达式对象RegExp test方法慎用/g
- javascript 中 getter 方法的陷阱
- 简述JavaScript的正则表达式中test()方法的使用
- JavaScript正则表达式(二)实例方法test
- 笔记 javascript test()方法
- JavaScript中级 --- 正则常用方法 exec、match、replace、test、$n
- JavaScript中正则表达式RegExp对象的test方法
- javascript正则表达式对象方法 compile() exec() test()的比较
- 注意 JavaScript 中 RegExp 对象的 test 方法
- 注意 JavaScript 中 RegExp 对象的 test 方法