?
由于match和exec在匹配成功的時(shí)候返回都是數(shù)組,沒有匹配的時(shí)候返回是null,因襲很多小伙伴們都會以為這兩個(gè)的效果是一樣的,其實(shí)不然,那么下面我們就一起去看看JS正則中如何使用match與exec吧。
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í)例:
?
匹配的結(jié)果如下:
?
?
?
?
返回的匹配數(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è)對象屬性。index 屬性聲明的是匹配文本的起始字符在目標(biāo)字符串中的位置,input 屬性聲明的是對目標(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ù)組是相同的。 ? ? |
沿用上面的例子:
新聞熱點(diǎn)
疑難解答