JavaScript 中的 RegExp 對象用於Regex相關的操作,這個對象提供了一個方法 test 來判定某個字串是否滿足某個 pattern. 傳回值是 true/false.
今天我碰到了一個問題:
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]
這裡兩個測試的字串應該都滿足Regex中的模式,返回 true. 可是測試結果卻依次是:true, false.
我估計問題的原因可能是因為 RegExp 對象是有狀態的,並且在 test 方法的執行時會在某個步驟中利用到狀態資訊,這樣就造成了錯誤。
(註:RegExp 全域對象有一些靜態屬性和方法,比如 RegExp.$1... RegExp$9, 等)
解決這個問題的辦法也很簡單,就是每次重新初始化一次Regex對象:
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]
在我看來,JavaScript 中Regex的這個行為設計的很奇怪,應該說是和正常使用習慣有那麼一點點的不同。雖然使用了很久的 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