浅谈regExp的test方法取得的值变化的原因及处理方法
1、JavaScript 正则表达式对象RegExp的test方法,用于检测一个字符串是否匹配某个模式。
字面量定义RegExp对象:var re = /pattern/attributes,其中attributes可以是g,i,m;
阅读以下程序:
<script type="text/javascript"> var str = 'abc123'; var re = /^abc/g ; var result1 = re.test(str); var result2 = re.test(str); var result3 = re.test(str); document.write('result1:' + result1 + '<br/>'); document.write('result2:' + result2 + '<br/>'); document.write('result3:' + result3); </script>
我们会认为打印结果应该是true;true;true;
而实际情况却是true;false;true;
2、为什么第二个结果是false?
发现RegExp对象有一个lastIndex的属性,如果使用了全局修饰符,那么执行test方法后,lastIndex就会记录匹配的字符串在原始字 符串中最后一位的索引加一,例如执行了var result1 = re.test(str)后lastIndex为3(document.write('re.lastindex:' + re.lastIndex+ '<br/>');),如果没有发现匹配lastIndex置为0。当下次再执行时,对给定的字符串匹配不是从开头位置,而是要依据lastIndex提供的位置,由于这个原因,所以导致上例中result2的值为false。
3、处理方法:去除g;
即:var re = /^abc/g ;变为 var re = /^abc/;
以上这篇浅谈regExp的test方法取得的值变化的原因及处理方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
BootStrap点击保存后实现模态框自动关闭的思路(模态框)
这篇文章主要介绍了BootStrap点击保存后实现模态框自动关闭的思路(模态框),需要的朋友可以参考下2017-09-09JS/HTML5游戏常用算法之碰撞检测 包围盒检测算法详解【凹多边形的分离轴检测算法】
这篇文章主要介绍了JS/HTML5游戏常用算法之碰撞检测 包围盒检测算法,结合实例形式详细分析了javascript针对凹多边形的分离轴检测算法相关概念、原理、实现技巧与操作注意事项,需要的朋友可以参考下2018-12-12JavaScript中双等号(==)和三等号(===)有何不同以及何时使用它们详解
这篇文章主要给大家介绍了关于JavaScript中双等号(==)和三等号(===)有何不同以及何时使用它们的相关资料,在JavaScript中"=="和"==="都是比较运算符,用于比较两个值是否相等,需要的朋友可以参考下2024-01-01
最新评论