注意 JavaScript 中 RegExp 對象的 test 方法
更新時間:2007年01月09日 00:00:00 作者:
JavaScript 中的 RegExp 對象用于正則表達式相關(guān)的操作,這個對象提供了一個方法 test 來判定某個字符串是否滿足某個 pattern. 返回值是 true/false.
今天我碰到了一個問題:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]這里兩個測試的字符串應(yīng)該都滿足正則表達式中的模式,返回 true. 可是測試結(jié)果卻依次是:true, false.
我估計問題的原因可能是因為 RegExp 對象是有狀態(tài)的,并且在 test 方法的執(zhí)行時會在某個步驟中利用到狀態(tài)信息,這樣就造成了錯誤。
(注:RegExp 全局對象有一些靜態(tài)屬性和方法,比如 RegExp.$1... RegExp$9, 等)
解決這個問題的辦法也很簡單,就是每次重新初始化一次正則表達式對象:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]在我看來,JavaScript 中正則表達式的這個行為設(shè)計的很奇怪,應(yīng)該說是和正常使用習慣有那么一點點的不同。雖然使用了很久的 JavaScript, 卻一直沒有注意到這個奇怪的現(xiàn)象。其他語言比如 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了
對于你這個應(yīng)用環(huán)境來說,是不需要 "g" 的,其實 "i" 也不要,
匹配一個數(shù)字要區(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了
對于你這個應(yīng)用環(huán)境來說,是不需要 "g" 的,其實 "i" 也不要,
匹配一個數(shù)字要區(qū)分大小寫嗎??
不管加 "i" 還是加 "g" 都會讓你的代碼變慢。
建議只有在非常必要的情況下才加上ig
您可能感興趣的文章:
- JS正則中的RegExp對象對象
- javascript RegExp對象(正則表達式)
- JavaScript RegExp 正則表達式對象詳細說明
- js正則表達式講解之index屬性(RegExp對象)
- 詳解JavaScript正則表達式之RegExp對象
- JavaScript 正則表達式之RegExp屬性、方法及應(yīng)用分析
- JS正則RegExp.test()使用注意事項(不具有重復性)
- javascript RegExp 對象屬性與方法和應(yīng)用
- javascript類型系統(tǒng)_正則表達式RegExp類型詳解
- JavaScript使用RegExp進行正則匹配的方法
- JavaScript引用類型RegExp基本用法詳解
相關(guān)文章
JS實現(xiàn)動態(tài)添加DOM節(jié)點和事件的方法示例
這篇文章主要介紹了JS實現(xiàn)動態(tài)添加DOM節(jié)點和事件的方法,涉及javascript事件響應(yīng)及針對頁面dom元素節(jié)點與屬性的動態(tài)操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2017-04-04異步j(luò)avascript的原理和實現(xiàn)技巧介紹
因為工作的需要,我要在網(wǎng)頁端編寫一段腳本,把數(shù)據(jù)通過網(wǎng)頁批量提交到系統(tǒng)中去。所以我就想到了Greasemonkey插件,于是就開始動手寫,發(fā)現(xiàn)問題解決得很順利2012-11-11如何優(yōu)雅地取消 JavaScript 異步任務(wù)
這篇文章主要介紹了如何優(yōu)雅地取消 JavaScript 異步任務(wù),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-03-03js實現(xiàn)對table動態(tài)添加、刪除和更新的方法
這篇文章主要介紹了js實現(xiàn)對table動態(tài)添加、刪除和更新的方法,涉及javascript針對html中table表格節(jié)點的操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-02-02