注意 JavaScript 中 RegExp 對象的 test 方法
更新時間:2007年01月09日 00:00:00 作者:
JavaScript 中的 RegExp 對象用于正則表達式相關的操作,這個對象提供了一個方法 test 來判定某個字符串是否滿足某個 pattern. 返回值是 true/false.
今天我碰到了一個問題:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]這里兩個測試的字符串應該都滿足正則表達式中的模式,返回 true. 可是測試結果卻依次是:true, false.
我估計問題的原因可能是因為 RegExp 對象是有狀態(tài)的,并且在 test 方法的執(zhí)行時會在某個步驟中利用到狀態(tài)信息,這樣就造成了錯誤。
(注:RegExp 全局對象有一些靜態(tài)屬性和方法,比如 RegExp.$1... RegExp$9, 等)
解決這個問題的辦法也很簡單,就是每次重新初始化一次正則表達式對象:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]在我看來,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了
對于你這個應用環(huán)境來說,是不需要 "g" 的,其實 "i" 也不要,
匹配一個數字要區(qū)分大小寫嗎??
不管加 "i" 還是加 "g" 都會讓你的代碼變慢。
建議只有在非常必要的情況下才加上ig
今天我碰到了一個問題:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
我估計問題的原因可能是因為 RegExp 對象是有狀態(tài)的,并且在 test 方法的執(zhí)行時會在某個步驟中利用到狀態(tài)信息,這樣就造成了錯誤。
(注:RegExp 全局對象有一些靜態(tài)屬性和方法,比如 RegExp.$1... RegExp$9, 等)
解決這個問題的辦法也很簡單,就是每次重新初始化一次正則表達式對象:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
了解這個問題詳細原因的朋友,請不吝指教。
當然,你用了全局匹配模式 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了
對于你這個應用環(huán)境來說,是不需要 "g" 的,其實 "i" 也不要,
匹配一個數字要區(qū)分大小寫嗎??
不管加 "i" 還是加 "g" 都會讓你的代碼變慢。
建議只有在非常必要的情況下才加上ig
您可能感興趣的文章:
- JS正則中的RegExp對象對象
- javascript RegExp對象(正則表達式)
- JavaScript RegExp 正則表達式對象詳細說明
- js正則表達式講解之index屬性(RegExp對象)
- 詳解JavaScript正則表達式之RegExp對象
- JavaScript 正則表達式之RegExp屬性、方法及應用分析
- JS正則RegExp.test()使用注意事項(不具有重復性)
- javascript RegExp 對象屬性與方法和應用
- javascript類型系統(tǒng)_正則表達式RegExp類型詳解
- JavaScript使用RegExp進行正則匹配的方法
- JavaScript引用類型RegExp基本用法詳解
相關文章
JS實現動態(tài)添加DOM節(jié)點和事件的方法示例
這篇文章主要介紹了JS實現動態(tài)添加DOM節(jié)點和事件的方法,涉及javascript事件響應及針對頁面dom元素節(jié)點與屬性的動態(tài)操作相關實現技巧,需要的朋友可以參考下2017-04-04