JS正則中的match與exec使用說明
主要參考W3C教程
String.match()
match() 方法將檢索目標(biāo)字符串,以找到一個(gè)或多個(gè)與 正則表達(dá)式regexp 匹配的文本。match()有兩種情況:
<!--[if !supportLists]-->1、 <!--[endif]-->如果 regexp 具有標(biāo)志 g,則 match() 方法將執(zhí)行全局檢索,找到目標(biāo)字符串中的所有匹配子字符串。
匹配情況 |
返回值 |
沒有找到任何匹配的子串 |
null |
找到了一個(gè)或多個(gè)匹配子串 |
一個(gè)數(shù)組。數(shù)組的內(nèi)容包含所有的匹配子串 |
下面是個(gè)實(shí)例:
var str = 'xxtest00test11test22test'
regexp = new RegExp(/(test)(.{1})/g);
while((result = regexp.exec(str)) != null){
document.write(result + '<br />');
document.write(regexp.lastIndex+ '<br />');
}
返回的匹配數(shù)組:
[testaa,testbb,testcc]
并且數(shù)組不包含其他有關(guān)匹配的信息:
0:testaa
1:testbb
2:testcc
<!--[if !supportLists]-->2、 <!--[endif]-->如果 regexp 沒有標(biāo)志 g,那么 match() 方法就只能目標(biāo)字符串中執(zhí)行一次匹配。
匹配情況 |
返回值 |
沒有找到任何匹配的子串 |
null |
找到了一個(gè)或多個(gè)匹配子串 |
一個(gè)數(shù)組。數(shù)組的內(nèi)容包含與它找到的匹配文本有關(guān)的信息。該數(shù)組的第 0 個(gè)元素存放的是匹配文本,而其余的元素存放的是與正則表達(dá)式的子表達(dá)式匹配的文本。除了這些常規(guī)的數(shù)組元素之外,返回的數(shù)組還含有兩個(gè)對(duì)象屬性。index 屬性聲明的是匹配文本的起始字符在目標(biāo)字符串中的位置,input 屬性聲明的是對(duì)目標(biāo)字符串的引用。 |
我們把上面例子的全局標(biāo)志g拿掉,regexp = new RegExp(/(test)(.{1})/);再次得到的匹配結(jié)果如下:
返回的匹配數(shù)組:
[test0,test,0]
并且數(shù)組包含index和input信息:
0:test0
1:test
2:0
index:2
input:xxtest0test1test2test
不過有一點(diǎn)需要說明的是,在IE6,7,8下,返回的數(shù)組同時(shí)包含lastIndex信息,用來表示表示匹配子串的下一個(gè)位置。話說這個(gè)屬性應(yīng)該是在regexp上面的,所以在IE9里面去掉了。
String.exec()方法:
<!--[if !supportLists]-->1、 <!--[endif]-->如果 regexp 不具有標(biāo)志 g。
匹配情況 |
返回值 |
沒有找到任何匹配的子串 |
null |
找到了一個(gè)或多個(gè)匹配子串 |
一個(gè)數(shù)組。數(shù)組的內(nèi)容與調(diào)用match() 返回的數(shù)組是相同的。 |
沿用上面的例子:
result = regexp.exec(str);
返回的匹配數(shù)組:
[test0,test,0]
并且數(shù)組包含index和input信息:
0:test0
1:test
2:0
index:2
input:xxtest0test1test2test
同樣,在IE6,7,8下,返回的數(shù)組同時(shí)包含lastIndex信息。
<!--[if !supportLists]-->2、 <!--[endif]-->如果 regexp 具有標(biāo)志 g。
它會(huì)在 regexp的 lastIndex 屬性指定的字符處開始檢索。當(dāng) exec() 找到了與表達(dá)式相匹配的文本時(shí),在匹配后,它將把 regexp的 lastIndex 屬性設(shè)置為匹配文本的最后一個(gè)字符的下一個(gè)位置。這就是說,可以通過反復(fù)調(diào)用 exec() 方法來遍歷字符串中的所有匹配文本。當(dāng) exec() 再也找不到匹配的文本時(shí),它將返回 null,并把 lastIndex 屬性重置為 0。
注:無論 RegExpObject 是否是全局模式,exec() 都會(huì)把完整的細(xì)節(jié)添加到它返回的數(shù)組中。這就是 exec() 與 match() 的不同之處,后者在全局模式下返回的信息要少得多。如果要獲得所有的匹配細(xì)節(jié),就可以在全局模式下循環(huán)調(diào)用exec()方法。
類似:
var str = 'xxtest00test11test22test'
regexp = new RegExp(/(test)(.{1})/g);
while((result = regexp.exec(str)) != null){
document.write(result + '<br />');
document.write(regexp.lastIndex+ '<br />');
}
對(duì)于lastIndex屬性的說明:
<!--[if !supportLists]-->(1) <!--[endif]-->lastIndex在regexp上面,而不是返回的數(shù)組結(jié)果里面,IE6,7,8在match()方法的lastIndex實(shí)現(xiàn)上有bug。
<!--[if !supportLists]-->(2) <!--[endif]-->如果在一個(gè)字符串中完成了一次模式匹配之后要開始檢索新的字符串,就必須手動(dòng)地把 lastIndex 屬性重置為 0。
- js正則函數(shù)match、exec、test、search、replace、split使用介紹集合
- js正則表達(dá)式之match函數(shù)講解
- javascript中match函數(shù)的用法小結(jié)
- 簡介JavaScript中charAt()方法的使用
- js charAt的使用示例
- JavaScript charCodeAt方法入門實(shí)例(用于取得指定位置字符的Unicode編碼)
- js Map List 遍歷使用示例
- JS Map 和 List 的簡單實(shí)現(xiàn)代碼
- js實(shí)現(xiàn)的map方法示例代碼
- js正則表達(dá)式之search方法講解
- js中exec、test、match、search、replace、split用法
- JS常見疑難點(diǎn)分析之match,charAt,charCodeAt,map,search用法分析
相關(guān)文章
用Java正則去掉字符串中重復(fù)出現(xiàn)的字符
abcde 順序可以不一樣,也就是去掉重復(fù)出現(xiàn)的字符2010-12-12在ASP中用正則表達(dá)式對(duì)象來校驗(yàn)數(shù)據(jù)的合法性
我們?cè)谥谱骶W(wǎng)站的時(shí)候,需要對(duì)用戶輸入的數(shù)據(jù)進(jìn)行驗(yàn)證,前端是輔助用戶方便填寫,后端才是真正的安全過濾,正則表達(dá)式對(duì)于一些數(shù)據(jù)校驗(yàn)都是比較常見的不只asp中需要,php也需要,這里腳本之家小白就為大家簡單介紹一下2006-06-06正則表達(dá)式特別需要注意的點(diǎn):“空“字符的匹配方法
這篇文章主要介紹了正則表達(dá)式特別需要注意的點(diǎn):“空“字符的匹配,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03