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