欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

注意 JavaScript 中 RegExp 對象的 test 方法

 更新時間:2007年01月09日 00:00:00   作者:  
JavaScript 中的 RegExp 對象用于正則表達式相關(guān)的操作,這個對象提供了一個方法 test 來判定某個字符串是否滿足某個 pattern. 返回值是 true/false.
今天我碰到了一個問題:

這里兩個測試的字符串應(yīng)該都滿足正則表達式中的模式,返回 true. 可是測試結(jié)果卻依次是:true, false.

我估計問題的原因可能是因為 RegExp 對象是有狀態(tài)的,并且在 test 方法的執(zhí)行時會在某個步驟中利用到狀態(tài)信息,這樣就造成了錯誤。
(注:RegExp 全局對象有一些靜態(tài)屬性和方法,比如 RegExp.$1... RegExp$9, 等)

解決這個問題的辦法也很簡單,就是每次重新初始化一次正則表達式對象:

在我看來,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   

相關(guān)文章

最新評論