字符 | 替換文本 |
---|---|
$1、$2、...、$99 | 與regexp中的第1個(gè)到99 個(gè)子表達(dá)式相匹配的文本 |
$ | 與regexp相匹配的字串 |
$` | 位于匹配子串左側(cè)的文本 |
$' | 位于匹配子串右側(cè)的文本 |
$$ | 直接量符號(hào) |
來(lái)看下例子:
//1、用子表達(dá)式替換:$1、$2等 var str = "javascript"; str.replace(/(java)(script)/,'$2$1'); // 表達(dá)式中()就是一個(gè)子表達(dá)式,$1對(duì)應(yīng)是第一個(gè)表達(dá)式的內(nèi)容,即java,$2為script,所以替換結(jié)果為:scriptjava //2、$ 為正值表達(dá)式匹配的字串 var str = "javascript"; str.replace(/java/,'$-'); // 正則表達(dá)式通過(guò)直接量java來(lái)匹配,匹配結(jié)果為java,則 $的值為java,然后用字符串$-來(lái)替換匹配的字串,結(jié)果為java-script // 3、 $` $' $$ var str = "javascript"; str.replace(/ava/,"$`"); // $`為匹配子串a(chǎn)va的左側(cè)文本,則為j,則替換后ava的結(jié)果為:jjscript str.replace(/ava/,"$'"); // $'為匹配子串a(chǎn)va的右側(cè)文本,則為script,則替換ava的結(jié)果為:jscriptscript str.replace(/ava/,"$$"); // $$為直接量符號(hào),即插入一個(gè)$符號(hào),替換結(jié)果為:j$script
4、使用replacement作為函數(shù)替換
replace的參數(shù)replacement可以是函數(shù)而不是字符串,每個(gè)匹配都會(huì)調(diào)用該函數(shù),它返回的字符串將作為替換的文本使用。該函數(shù)的第一個(gè)參數(shù)是整個(gè)匹配模式的字符串,接下來(lái)的參數(shù)是與模式中的子表達(dá)式匹配的字符串,可以有0個(gè)或多個(gè)參數(shù)。接下來(lái)的參數(shù)是一個(gè)整數(shù),聲明了匹配在str中出現(xiàn)的位置。最后的參數(shù)是str自身。
來(lái)看個(gè)例子:
// match 為匹配整個(gè)字符串,即:'abc12345#$*%' // p1 為第一個(gè)子表達(dá)式,([^\d]*),匹配0個(gè)或多個(gè)非數(shù)字的字符,即:abc // p2 為第二個(gè)子表達(dá)式,(\d*),匹配0個(gè)或多個(gè)的數(shù)字,即:12345 // p3 為第三個(gè)子表達(dá)式,([^\w]*),匹配0個(gè)或匹配任何非單詞字符。等價(jià)于 '[^A-Za-z0-9_]',即 #$*% // offset 為模式匹配出現(xiàn)的位置,從第一個(gè)字符已經(jīng)匹配成功,則位置為0 // string為字符串本身,即 abc12345#$*% function replacer(match, p1, p2, p3, offset, string) { return [p1, p2, p3].join(' - '); } var newString = 'abc12345#$*%'.replace(/([^\d]*)(\d*)([^\w]*)/, replacer); // 替換結(jié)果為:abc - 12345 - #$*%
str.match(regexp)
定義:match()方法是最常用的String正則表達(dá)式方法。它唯一的參數(shù)就是一個(gè)正則表達(dá)式或者通過(guò)RegExp()構(gòu)造函數(shù)來(lái)創(chuàng)建正則表達(dá)式,返回值是包含了匹配結(jié)果的數(shù)組。
match()方法中的regexp正則表達(dá)式一般又分為兩種情況:有設(shè)置全局標(biāo)志g和沒(méi)有設(shè)置全局標(biāo)志g
1、有設(shè)置全局標(biāo)志
如果設(shè)置了全局標(biāo)志g,則返回的數(shù)組包含的就是出現(xiàn)在字符串的所有匹配結(jié)果,例如:
// 全局匹配 var str = "1 plus 2 equals 3"; str.match(/\d/g); // 匹配字符串中出現(xiàn)的所有數(shù)字,并返回一個(gè)數(shù)組: [1,2,3]
2、沒(méi)有設(shè)置全局標(biāo)志
如果沒(méi)有設(shè)置全局標(biāo)志,則就不是全局性的檢索,只是檢索第一個(gè)匹配。這種情況下,match()方法匹配的結(jié)果也是返回一個(gè)數(shù)組,數(shù)組的第一個(gè)元素就是匹配的字符串,而余下的元素則是正則表達(dá)式中用括號(hào)括起來(lái)的子表達(dá)式。來(lái)看個(gè)例子:
// 非全局匹配 var str = "visit my blog at http://www.example.com"; str.match(/(\w+):\/\/([\w.]+)/); // 返回結(jié)果:["http://www.example.com", "http", "www.example.com"] // 正則表達(dá)式匹配的結(jié)果為:http://www.example.com // 第一個(gè)子表達(dá)式 (\w+)匹配結(jié)果:http // 第二個(gè)子表達(dá)式 ([\w.])匹配結(jié)果: www.example.com
str.split(delimiter, limit)
定義:split()方法可以把調(diào)用它的字符串分解為一個(gè)字串?dāng)?shù)組,使用的分隔符是它的參數(shù)。
參數(shù):
delimiter:字符串或者正則表達(dá)式,從該參數(shù)指定的地方分割字符串。
limit:指定返回?cái)?shù)組的最大長(zhǎng)度,如果沒(méi)有設(shè)置該參數(shù),則整個(gè)字符串都會(huì)被分割。
例如:
//1、 只傳一個(gè)參數(shù),默認(rèn)分割整個(gè)字符串 var str ="a,b,c,d,e"; str.split(','); // 返回分割的字符串?dāng)?shù)組:["a", "b", "c", "d", "e"] //2、傳入兩個(gè)參數(shù) var str ="a,b,c,d,e"; str.split(',',3); //指定限定長(zhǎng)度,則返回對(duì)應(yīng)的數(shù)組:["a", "b", "c"] //3、使用正則表達(dá)式匹配,不包含分割字符串 var str = "aa44bb55cc66dd"; str.split(/\d+/); //通過(guò)匹配數(shù)字進(jìn)行分割字符串,但不包含分割的字符串,則返回的結(jié)果為:["aa","bb","cc","dd"]; //4、使用正則表達(dá)式匹配,包含分割字符串 var str = "aa44bb55cc66dd"; str.split(/(\d+)/); //通過(guò)匹配數(shù)字進(jìn)行分割字符串,且分割的字符串是包含在子表達(dá)式中,則返回的結(jié)果為:["aa", "44", "bb", "55", "cc", "66", "dd"]
關(guān)于正則表達(dá)式模式匹配的String方法的相關(guān)知識(shí),小編就給大家介紹到這里,希望對(duì)大家有所幫助!
標(biāo)簽:池州 咸陽(yáng) 恩施 六安 鞍山 三亞 綿陽(yáng) 梅州
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《正則表達(dá)式模式匹配的String方法》,本文關(guān)鍵詞 正則,表達(dá)式,模式,匹配,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。