DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript綜合知識 >> js正則表達exec與match的區別說明
js正則表達exec與match的區別說明
編輯:JavaScript綜合知識     

 本篇文章主要是對js正則表達exec與match的區別進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助

以前用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則於全局相關聯,當定義為非全局,兩者執行結果相同  
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved