首頁 > web前端 > js教程 > js正規表達exec與match的區別說明_javascript技巧

js正規表達exec與match的區別說明_javascript技巧

WBOY
發布: 2016-05-16 17:01:43
原創
1004 人瀏覽過

以前用js很少用到js的正規表示式,即使用到了,也是諸如郵件名稱之類的判斷,網上代碼很多,很少有研究,拿來即用。

最近開發遇到一些需要使用正規表示式,順便研究一下

正規表示式物件有兩個定義方式::

1、第一種定義:

new RegExp(pattern, attributes);如var reg = new RegExp("abc","g")

其中pattern為表示表達式內容,如上表示匹配abc

attributes:g,全域匹配,i不區分大小寫,m執行多行匹配,用最多的為g和i

2、第二種定義:/pattern/attributes.

如:var reg = /abc/g;

正規表達的規則一些規則在此不再說明,只記錄exec和match的區別:

1、exec是正規表示式的方法,而不是字串的方法,它的參數才是字串,如下所示:

如上定義
var reg = new RegExp("abc") ;
var str = "3abc4,5abc6";
reg.exec(str ); 

2、match是字串執行匹配正規表示式規則的方法,他的參數是正規表達,如

var reg = new RegExp("abc") ;
var str = "3abc4,5abc6";
str.match(reg);

3、exec和match回傳的都是陣列;

如果exec執行的正規表示式沒有子表達式(小括號內的內容,如/abc(s*)/中的(s*) ),如果有匹配,就傳回第一個匹配的字串內容,此時的陣列僅有一個元素,如果沒有符合返回null;

var reg = new RegExp("abc") ;
var str = "3abc4,5abc6";
alert(reg.exec(str));
alert(str.match(reg) );

執行如上程式碼,你會發現兩者內容都是一樣:abc,

4、如果定義正規表示物件為全域匹配如:

var reg = new RegExp("abc","g") ;
var str = "3abc4,5abc6";
alert(reg.exec(str));
alert(str. match(reg));

則 為abc和abc,abc;因為match執行了全域比對查詢;而exec如果沒有子運算式只會找到一個符合的即回傳。

5.當表示中含有子表達式的情況:

var reg = new RegExp("a(bc)") ;
var str = "3abc4,5abc6";
alert(reg.exec(str));
alert(str.match (reg));

你會發現兩者執行的結果都是:abc,bc;

6、當如果正規表示式物件定義為為全域匹配

var reg = new RegExp("a(bc)","g") ;
var str = "3abc4,5abc6";
alert(reg.exec(str));
alert (str.match(reg));

則兩者回傳的結果是abc,bc和abc,abc,

總結為:

1、當正規表示式無子表達式,且定義為非全域匹配時,exec和match執行的結果是一樣,均傳回第一個符合的字串內容;

2、當正規表示式無子表達式,且定義為全域匹配時,exec和match執行,做存在多處符合內容,則match傳回的是多個元素數組;

3、當正規表示式有子表示時,且定義為非全域匹配,exec和match執行的結果是一樣如上邊的第5種情況;

4、當正規表示式有子表示時,且定義為全域匹配,exec和match執行的結果不一樣,此時match將忽略子表達式,只尋找全匹配正規表示式並傳回所有內容,如上第6種情況;

也就說,exec與全域是否定義無關係,而match則於全域相關聯,當定義為非全域,兩者執行結果相同

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板