主頁 > 知識庫 > JS正則中的match與exec使用說明

JS正則中的match與exec使用說明

熱門標簽:地圖標注店鋪地圖標注酒店 山東外呼系統(tǒng)聯(lián)系方式 淄博市張店區(qū)地圖標注 浙江營銷外呼系統(tǒng)有哪些 遼寧秒客來電話機器人 自己做的電銷機器人 惠安地圖標注 上海銷售電銷機器人軟件 哈爾濱公司外呼系統(tǒng)代理

主要參考W3C教程

String.match()

match() 方法將檢索目標字符串,以找到一個或多個與 正則表達式regexp 匹配的文本。match()有兩種情況:

!--[if !supportLists]-->1、 !--[endif]-->如果 regexp 具有標志 g,則 match() 方法將執(zhí)行全局檢索,找到目標字符串中的所有匹配子字符串。

匹配情況

返回值

沒有找到任何匹配的子串

null

找到了一個或多個匹配子串

一個數(shù)組。數(shù)組的內(nèi)容包含所有的匹配子串

下面是個實例:

復制代碼 代碼如下:

var str = 'xxtest00test11test22test'
regexp = new RegExp(/(test)(.{1})/g);
while((result = regexp.exec(str)) != null){
document.write(result + 'br />');
document.write(regexp.lastIndex+ 'br />');
}

匹配的結(jié)果如下:

返回的匹配數(shù)組:

[testaa,testbb,testcc]
并且數(shù)組不包含其他有關(guān)匹配的信息:

   0:testaa
   1:testbb
   2:testcc

!--[if !supportLists]-->2、 !--[endif]-->如果 regexp 沒有標志 g,那么 match() 方法就只能目標字符串中執(zhí)行一次匹配。

匹配情況

返回值

沒有找到任何匹配的子串

null

找到了一個或多個匹配子串

一個數(shù)組。數(shù)組的內(nèi)容包含與它找到的匹配文本有關(guān)的信息。該數(shù)組的第 0 個元素存放的是匹配文本,而其余的元素存放的是與正則表達式的子表達式匹配的文本。除了這些常規(guī)的數(shù)組元素之外,返回的數(shù)組還含有兩個對象屬性。index 屬性聲明的是匹配文本的起始字符在目標字符串中的位置,input 屬性聲明的是對目標字符串的引用。

我們把上面例子的全局標志g拿掉,regexp = new RegExp(/(test)(.{1})/);再次得到的匹配結(jié)果如下:

返回的匹配數(shù)組:

[test0,test,0]
并且數(shù)組包含indexinput信息:

0:test0
1:test
2:0
index:2
input:xxtest0test1test2test

不過有一點需要說明的是,在IE6,7,8下,返回的數(shù)組同時包含lastIndex信息,用來表示表示匹配子串的下一個位置。話說這個屬性應該是在regexp上面的,所以在IE9里面去掉了。

String.exec()方法:

!--[if !supportLists]-->1、 !--[endif]-->如果 regexp 不具有標志 g。

匹配情況

返回值

沒有找到任何匹配的子串

null

找到了一個或多個匹配子串

一個數(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ù)組同時包含lastIndex信息。
!--[if !supportLists]-->2、 !--[endif]-->如果 regexp 具有標志 g。
它會在 regexp的 lastIndex 屬性指定的字符處開始檢索。當 exec() 找到了與表達式相匹配的文本時,在匹配后,它將把 regexp的 lastIndex 屬性設(shè)置為匹配文本的最后一個字符的下一個位置。這就是說,可以通過反復調(diào)用 exec() 方法來遍歷字符串中的所有匹配文本。當 exec() 再也找不到匹配的文本時,它將返回 null,并把 lastIndex 屬性重置為 0。
注:無論 RegExpObject 是否是全局模式,exec() 都會把完整的細節(jié)添加到它返回的數(shù)組中。這就是 exec() 與 match() 的不同之處,后者在全局模式下返回的信息要少得多。如果要獲得所有的匹配細節(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 />');
}

對于lastIndex屬性的說明:
!--[if !supportLists]-->(1) !--[endif]-->lastIndex在regexp上面,而不是返回的數(shù)組結(jié)果里面,IE6,7,8在match()方法的lastIndex實現(xiàn)上有bug。
!--[if !supportLists]-->(2) !--[endif]-->如果在一個字符串中完成了一次模式匹配之后要開始檢索新的字符串,就必須手動地把 lastIndex 屬性重置為 0。

您可能感興趣的文章:
  • js正則函數(shù)match、exec、test、search、replace、split使用介紹集合
  • js正則表達式之match函數(shù)講解
  • javascript中match函數(shù)的用法小結(jié)
  • 簡介JavaScript中charAt()方法的使用
  • js charAt的使用示例
  • JavaScript charCodeAt方法入門實例(用于取得指定位置字符的Unicode編碼)
  • js Map List 遍歷使用示例
  • JS Map 和 List 的簡單實現(xiàn)代碼
  • js實現(xiàn)的map方法示例代碼
  • js正則表達式之search方法講解
  • js中exec、test、match、search、replace、split用法
  • JS常見疑難點分析之match,charAt,charCodeAt,map,search用法分析

標簽:重慶 泰州 長沙 宣城 銅川 西安 無錫 綿陽

巨人網(wǎng)絡(luò)通訊聲明:本文標題《JS正則中的match與exec使用說明》,本文關(guān)鍵詞  正則,中的,match,與,exec,使用說明,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《JS正則中的match與exec使用說明》相關(guān)的同類信息!
  • 本頁收集關(guān)于JS正則中的match與exec使用說明的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章