深入剖析javascript中的exec與match方法
exec是正則表達(dá)式的方法,而不是字符串的方法,它的參數(shù)才是字符串,如下所示:
var re=new RegExp(/\d/); re.exec( "abc4def" ); //或者使用perl風(fēng)格: /\d/.exec( "abc4def" ); //match才是字符串類提供的方法,它的參數(shù)是正則表達(dá)式對象,如下用法是正確的: "abc4def".match(\d);
exec和match返回的都是數(shù)組
如果執(zhí)行exec方法的正則表達(dá)式?jīng)]有分組(沒有括號括起來的內(nèi)容),那么如果有匹配,他將返回一個只有一個元素的數(shù)組,這個數(shù)組唯一的元素就是該正則表達(dá)式匹配的第一個串;如果沒有匹配則返回null。
下面兩個alert函數(shù)彈出的信息是一樣的:
var str= "cat,hat" ; var p=/at/; //沒有g(shù)屬性 alert(p.exec(str)) alert(str.match(p))
都是"at"。在這種場合下exec等價于match。
但是如果正則表達(dá)式是全局匹配(g屬性)的,那么以上代碼結(jié)果不一樣了:
var str= "cat,hat" ; var p=/at/g; //注意g屬性 alert(p.exec(str)) alert(str.match(p))
分別是
"at"
"at,at"。
因?yàn)閑xec永遠(yuǎn)只返回第一個匹配,而match在正則指定了g屬性的時候,會返回所有匹配。
exec如果找到了匹配,而且包含分組的話,返回的數(shù)組將包含多個元素,第一個元素是找到的匹配,之后的元素依次為該匹配中的第一、第二...個分組(反向引用)
如下的代碼將彈出"cat2,at":
var str= "cat2,hat8" ; var p=/c(at)\d/; alert(p.exec(str))
其中第一個元素是匹配的字符串"cat2",之后的元素是括號中匹配的"at"。
match函數(shù)在滿足如下條件下將越俎代庖,實(shí)現(xiàn)和exec一樣的功能:
1、正則表達(dá)式中含有分組(括號)
2、返回唯一的匹配
且看如下的代碼:
var str= "cat2,hat8" ; var p=/c(at)\d/; alert(p.exec(str)) alert(str.match(p))
都將彈出消息"cat2,at",是不是覺得很奇怪呢?
總結(jié):
match是返回所有匹配的字符串合成的數(shù)組,但是正則表達(dá)式必須指定全局g屬性才能返回所有匹配,不指定g屬性則會返回一個只有一個元素的數(shù)組。
exec永遠(yuǎn)返回與第一個匹配相關(guān)的信息,其返回?cái)?shù)組包括第一個匹配的字串,所有分組的反向引用。
某些情況下exec返回的結(jié)果和match返回的結(jié)果一樣:
var str= "cat,hat" ; var p=/at/; //沒有g(shù)屬性 alert(p.exec(str)) alert(str.match(p))
都彈出“at”
某些情況下match返回的結(jié)果和exec返回的結(jié)果一樣:
var str= "cat2,hat8" ; var p=/c(at)\d/; alert(p.exec(str)) alert(str.match(p))
都彈出“cat2,at”
以上這篇深入剖析javascript中的exec與match方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
從0到1學(xué)習(xí)JavaScript編寫貪吃蛇游戲
這篇文章主要為大家詳細(xì)介紹了JavaScript編寫貪吃蛇游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-07-07
微信小程序?qū)崿F(xiàn)點(diǎn)擊生成隨機(jī)驗(yàn)證碼
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)點(diǎn)擊生成隨機(jī)驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-09-09
JS遠(yuǎn)程獲取網(wǎng)頁源代碼實(shí)例
獲取網(wǎng)頁源代碼的方法有很多,本文為大家介紹下使用JS是如何做到的,感興趣的朋友可以學(xué)習(xí)下哦2013-09-09
BootStrap表單控件之復(fù)選框checkbox和單選擇按鈕radio
這篇文章主要介紹了BootStrap表單控件之復(fù)選框checkbox和單選擇按鈕radio的相關(guān)資料,需要的朋友可以參考下2017-05-05
JavaScript實(shí)現(xiàn)復(fù)制粘貼剪切功能三種方法
這篇文章主要給大家介紹了關(guān)于JavaScript實(shí)現(xiàn)復(fù)制粘貼剪切功能的相關(guān)資料,在實(shí)際案例的操作過程中,不少人都會遇到這樣的開發(fā)需求,文中通過代碼將三種方法介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01
Javascript在IE或Firefox下獲取鼠標(biāo)位置的代碼
由于Firefox和IE等瀏覽器之間對JS解釋的方式不一樣,F(xiàn)irefox下面獲取鼠標(biāo)位置不能夠直接使用clientX來獲取。網(wǎng)上說的一般都是觸發(fā)mousemove事件才行。我這里有兩段代碼,思路都一樣,就是風(fēng)格不同。2009-12-12

