国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > regex > 正文

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

2020-01-20 22:16:45
字體:
來源:轉載
供稿:網友

主要參考W3C教程

String.match()

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

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

匹配情況

返回值

沒有找到任何匹配的子串

null

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

一個數組。數組的內容包含所有的匹配子串

下面是個實例:

復制代碼 代碼如下:

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

匹配的結果如下:

返回的匹配數組:

[testaa,testbb,testcc]
并且數組不包含其他有關匹配的信息:

   0:testaa
   1:testbb
   2:testcc

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

匹配情況

返回值

沒有找到任何匹配的子串

null

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

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

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

返回的匹配數組:

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

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

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

String.exec()方法:

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

匹配情況

返回值

沒有找到任何匹配的子串

null

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

一個數組。數組的內容與調用match() 返回的數組是相同的。

沿用上面的例子:

復制代碼 代碼如下:

result = regexp.exec(str);

返回的匹配數組:
[test0,test,0]
并且數組包含index和input信息:
0:test0
1:test
2:0
index:2
input:xxtest0test1test2test
同樣,在IE6,7,8下,返回的數組同時包含lastIndex信息。
<!--[if !supportLists]-->2、 <!--[endif]-->如果 regexp 具有標志 g。
它會在 regexp的 lastIndex 屬性指定的字符處開始檢索。當 exec() 找到了與表達式相匹配的文本時,在匹配后,它將把 regexp的 lastIndex 屬性設置為匹配文本的最后一個字符的下一個位置。這就是說,可以通過反復調用 exec() 方法來遍歷字符串中的所有匹配文本。當 exec() 再也找不到匹配的文本時,它將返回 null,并把 lastIndex 屬性重置為 0。
注:無論 RegExpObject 是否是全局模式,exec() 都會把完整的細節添加到它返回的數組中。這就是 exec() 與 match() 的不同之處,后者在全局模式下返回的信息要少得多。如果要獲得所有的匹配細節,就可以在全局模式下循環調用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上面,而不是返回的數組結果里面,IE6,7,8在match()方法的lastIndex實現上有bug。
<!--[if !supportLists]-->(2) <!--[endif]-->如果在一個字符串中完成了一次模式匹配之后要開始檢索新的字符串,就必須手動地把 lastIndex 屬性重置為 0。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 博野县| 舒兰市| 慈溪市| 普洱| 奈曼旗| 苗栗市| 长武县| 喜德县| 德安县| 库伦旗| 阿合奇县| 丽水市| 洛宁县| 新田县| 晴隆县| 海原县| 泸水县| 沽源县| 怀宁县| 永丰县| 襄垣县| 门源| 南澳县| 阿合奇县| 新营市| 卫辉市| 天峨县| 舟山市| 甘洛县| 蒙山县| 铜鼓县| 盐城市| 舒兰市| 汕尾市| 于都县| 防城港市| 永德县| 乾安县| 安阳市| 连云港市| 武定县|