最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
浅谈regExp的test方法取得的值变化的原因及处理方法
时间:2017-05-11 编辑:简简单单 来源:一聚教程网
1、JavaScript 正则表达式对象RegExp的test方法,用于检测一个字符串是否匹配某个模式。
字面量定义RegExp对象:var re = /pattern/attributes,其中attributes可以是g,i,m;
阅读以下程序:
代码如下 | 复制代码 |
varstr ='abc123'; varre = /^abc/g ; varresult1 = re.test(str); varresult2 = re.test(str); varresult3 = re.test(str); document.write('result1:'+ result1 +' document.write('result2:'+ result2 +' document.write('result3:'+ result3); |
我们会认为打印结果应该是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+ '
');),如果没有发现匹配lastIndex置为0。当下次再执行时,对给定的字符串匹配不是从开头位置,而是要依据lastIndex提供的位置,由于这个原因,所以导致上例中result2的值为false。
3、处理方法:去除g;
即:var re = /^abc/g ;变为 var re = /^abc/;
-
上一个: js for循环倒序输出数组元素的实例
-
下一个: 怎样在Laravel中增加自定义全局函数
相关文章
- C语言输入输出double值得处理 04-05
- VB图像处理,(二)二次线性插值的应用 01-12
- HTML简单购物数量小程序代码展示 10-31
- html canvas实现弹幕功能 10-31
- HTML中空格表示的意义 10-31
- html area标签解读 10-31