淺談regExp的test方法取得的值變化的原因及處理方法
1、JavaScript 正則表達(dá)式對象RegExp的test方法,用于檢測一個字符串是否匹配某個模式。
字面量定義RegExp對象:var re = /pattern/attributes,其中attributes可以是g,i,m;
閱讀以下程序:
<script type="text/javascript"> var str = 'abc123'; var re = /^abc/g ; var result1 = re.test(str); var result2 = re.test(str); var result3 = re.test(str); document.write('result1:' + result1 + '<br/>'); document.write('result2:' + result2 + '<br/>'); document.write('result3:' + result3); </script>
我們會認(rèn)為打印結(jié)果應(yīng)該是true;true;true;
而實際情況卻是true;false;true;
2、為什么第二個結(jié)果是false?
發(fā)現(xiàn)RegExp對象有一個lastIndex的屬性,如果使用了全局修飾符,那么執(zhí)行test方法后,lastIndex就會記錄匹配的字符串在原始字 符串中最后一位的索引加一,例如執(zhí)行了var result1 = re.test(str)后lastIndex為3(document.write('re.lastindex:' + re.lastIndex+ '<br/>');),如果沒有發(fā)現(xiàn)匹配lastIndex置為0。當(dāng)下次再執(zhí)行時,對給定的字符串匹配不是從開頭位置,而是要依據(jù)lastIndex提供的位置,由于這個原因,所以導(dǎo)致上例中result2的值為false。
3、處理方法:去除g;
即:var re = /^abc/g ;變?yōu)?var re = /^abc/;
以上這篇淺談regExp的test方法取得的值變化的原因及處理方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Javascript 定時器調(diào)用傳遞參數(shù)的方法
Javascript 定時器調(diào)用傳遞參數(shù)的方法,需要的朋友可以參考下。2009-11-11BootStrap點擊保存后實現(xiàn)模態(tài)框自動關(guān)閉的思路(模態(tài)框)
這篇文章主要介紹了BootStrap點擊保存后實現(xiàn)模態(tài)框自動關(guān)閉的思路(模態(tài)框),需要的朋友可以參考下2017-09-09JS/HTML5游戲常用算法之碰撞檢測 包圍盒檢測算法詳解【凹多邊形的分離軸檢測算法】
這篇文章主要介紹了JS/HTML5游戲常用算法之碰撞檢測 包圍盒檢測算法,結(jié)合實例形式詳細(xì)分析了javascript針對凹多邊形的分離軸檢測算法相關(guān)概念、原理、實現(xiàn)技巧與操作注意事項,需要的朋友可以參考下2018-12-12js模擬如何實現(xiàn)重載以及默認(rèn)參數(shù)
這篇文章主要介紹了js模擬如何實現(xiàn)重載以及默認(rèn)參數(shù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05JavaScript中雙等號(==)和三等號(===)有何不同以及何時使用它們詳解
這篇文章主要給大家介紹了關(guān)于JavaScript中雙等號(==)和三等號(===)有何不同以及何時使用它們的相關(guān)資料,在JavaScript中"=="和"==="都是比較運(yùn)算符,用于比較兩個值是否相等,需要的朋友可以參考下2024-01-01