注意 JavaScript 中 RegExp 对象的 test 方法

shine小宝丸子

shine小宝丸子

2016-02-19 10:56

下面图老师小编要向大家介绍下注意 JavaScript 中 RegExp 对象的 test 方法,看起来复杂实则是简单的,掌握好技巧就OK,喜欢就赶紧收藏起来吧!
JavaScript 中的 RegExp 对象用于正则表达式相关的操作,这个对象提供了一个方法 test 来判定某个字符串是否满足某个 pattern. 返回值是 true/false.
今天我碰到了一个问题:


[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]这里两个测试的字符串应该都满足正则表达式中的模式,返回 true. 可是测试结果却依次是:true, false.

我估计问题的原因可能是因为 RegExp 对象是有状态的,并且在 test 方法的执行时会在某个步骤中利用到状态信息,这样就造成了错误。
(注:RegExp 全局对象有一些静态属性和方法,比如 RegExp.$1... RegExp$9, 等)

解决这个问题的办法也很简单,就是每次重新初始化一次正则表达式对象:


[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]在我看来,JavaScript 中正则表达式的这个行为设计的很奇怪,应该说是和正常使用习惯有那么一点点的不同。虽然使用了很久的 JavaScript, 却一直没有注意到这个奇怪的现象。其他语言比如 Python, C# 等都不是这样的。

了解这个问题详细原因的朋友,请不吝指教。
当然,你用了全局匹配模式 g. 所以用完要重置 lastIndex 


var re = /^d+(?:.d)?$/ig; //== "ig" 
alert(re.test('112.3')); 
re.lastIndex=0 //加这句 
alert(re.test('33')); 

或者 

var re = /^d+(?:.d)?$/i; //== only "i", no g 
alert(re.test('112.3')); 
alert(re.test('33')); 


这样就OK了
对于你这个应用环境来说,是不需要 "g" 的,其实 "i" 也不要, 
匹配一个数字要区分大小写吗?? 

不管加 "i" 还是加 "g" 都会让你的代码变慢。 
建议只有在非常必要的情况下才加上ig   
展开更多 50%)
分享

猜你喜欢

注意 JavaScript 中 RegExp 对象的 test 方法

Web开发
注意 JavaScript 中 RegExp 对象的 test 方法

注意JavaScript中RegExp对象的test方法

Web开发
注意JavaScript中RegExp对象的test方法

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

javascript RegExp对象(正则表达式)

Web开发
javascript RegExp对象(正则表达式)

JavaScript replace new RegExp

Web开发
JavaScript replace new RegExp

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

JavaScript中的Function对象

Web开发
JavaScript中的Function对象

JavaScript中的其他对象

Web开发
JavaScript中的其他对象

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

Prototype1.5 rc2版指南最后一篇之Position

Prototype1.5 rc2版指南最后一篇之Position

iOS开发中使用cocos2d添加触摸事件的方法

iOS开发中使用cocos2d添加触摸事件的方法
下拉加载更多内容 ↓