閱讀目錄
- 正則表達(dá)式的創(chuàng)建
- 正則表達(dá)式中的特殊字符
- \ (反斜杠)
- ^
- $
- *, +, .(小數(shù)點(diǎn))
- ? (問(wèn)號(hào))
- (x)
- (?:x)
- x(?=y), x(?!y), x|y
- {n}, {n,m}:
- [xyz], [^xyz]
- 其他
- 正則表達(dá)式標(biāo)志
- 正則表達(dá)式使用
很多時(shí)候多會(huì)被正則表達(dá)式搞的暈頭轉(zhuǎn)向,最近抽出時(shí)間對(duì)正則表達(dá)式進(jìn)行了系統(tǒng)的學(xué)習(xí),整理如下:
正則表達(dá)式的創(chuàng)建
兩種方法,一種是直接寫(xiě),由包含在斜杠之間的模式組成;另一種是調(diào)用RegExp對(duì)象的構(gòu)造函數(shù)。
兩種方法的創(chuàng)建代碼如下:
// 直接創(chuàng)建
const regex1 = /ab+c/;
const regex2 = /^[a-zA-Z]+[0-9]*\W?_$/gi;
// 調(diào)用構(gòu)造函數(shù)
const regex3 = new RegExp('ab+c');
const regex4 = new RegExp(/^[a-zA-Z]+[0-9]*\W?_$/, "gi");
const regex5 = new RegExp('^[a-zA-Z]+[0-9]*\W?_$', 'gi');
可以看出,調(diào)用RegExp構(gòu)造函數(shù)創(chuàng)建正則表達(dá)式時(shí),第一個(gè)參數(shù)可以是字符串,也可以是直接創(chuàng)建的正則表達(dá)式。
需要注意的是:RegExp實(shí)例繼承的toLocaleString()和toString)()方法都會(huì)返回正則表達(dá)式的字面量,與創(chuàng)建正則表達(dá)式的方式無(wú)關(guān)
例如:
const ncname = '[a-zA-Z_][\\w\\-\\.]*';
const qnameCapture = '((?:' + ncname + '\\:)?' + ncname + ')';
const startTagOpen = new RegExp('^' + qnameCapture);
startTagOpen.toString(); // '/^((?:[a-zA-Z_][\w\-\.]*\:)?[a-zA-Z_][\w\-\.]*)/'
正則表達(dá)式中的特殊字符
\ (反斜杠)
1.在非特殊字符前加反斜杠表示下一個(gè)字符是特殊的;
2.將其后的特殊字符轉(zhuǎn)譯為字面量;
注意:在使用RegExp構(gòu)造函數(shù)時(shí)要將\轉(zhuǎn)譯,因?yàn)閈在字符串里也是轉(zhuǎn)譯字符
^
1.匹配輸入的開(kāi)始;
2.在[]中的第一位時(shí)表示反向字符集;
例子:
/^A/.exec('an A') // null
/^A/.exec('An E') // ["A", index: 0, input: "An E"]
$
匹配輸入的結(jié)束
/t$/.exec('eater') // null
/t$/.exec('eat') // ["t", index: 2, input: "eat"]
*, +, .(小數(shù)點(diǎn))
*:匹配前一個(gè)表達(dá)式0次或多次。等價(jià)于 {0,};
+:匹配前面一個(gè)表達(dá)式1次或者多次。等價(jià)于 {1,};
.:
匹配除換行符之外的任何單個(gè)字符;
? (問(wèn)號(hào))
1.匹配前面一個(gè)表達(dá)式0次或者1次。等價(jià)于 {0,1};
2.如果緊跟在任何量詞 * + ? {} 的后面,將會(huì)使量詞變?yōu)榉秦澙返模ㄆヅ浔M量少的字符),和缺省使用的貪婪模式正好相反;
3.運(yùn)用于先行斷言
例子:
/\d+/.exec('123abc') // ["123", index: 0, input: "123abc"]
/\d+?/.exec('123abc') // ["1", index: 0, input: "123abc"]
(x)
匹配 'x' 并且記住匹配項(xiàng),括號(hào)表示捕獲括號(hào);
例子:
/(foo) (bar) \1 \2/.test('bar foo bar foo'); // false
/(bar) (foo) \1 \2/.test('bar foo bar foo'); // true
/(bar) (foo) \1 \2/.test('bar foo'); // false
/(bar) (foo) \1 \2/.test('bar foo foo bar'); // false
/(bar) (foo) \2 \1/.test('bar foo foo bar'); // true
'bar foo bar foo'.replace( /(bar) (foo)/, '$2 $1' ); // "foo bar bar foo"
模式 /(foo) (bar) \1 \2/ 中的 '(foo)' 和 '(bar)' 匹配并記住字符串 "foo bar foo bar" 中前兩個(gè)單詞。模式中的 \1 和 \2 匹配字符串的后兩個(gè)單詞。
注意:\1、\2、\n 是用在正則表達(dá)式的匹配環(huán)節(jié),在正則表達(dá)式的替換環(huán)節(jié),則要使用像 $1、$2、$n 這樣的語(yǔ)法。例如,'bar foo'.replace( /(...) (...)/, '$2 $1' )。
(?:x)
匹配 'x' 但是不記住匹配項(xiàng),這種叫作非捕獲括號(hào);
例子:
'foo'.match(/foo{1,2}/) // ["foo", index: 0, input: "foo"]
'foo'.match(/(?:foo){1,2}/) // ["foo", index: 0, input: "foo"]
'foofoo'.match(/(?:foo){1,2}/) // ["foofoo", index: 0, input: "foofoo"]
'foofoo'.match(/foo{1,2}/) // ["foo", index: 0, input: "foofoo"]
使用場(chǎng)景:示例表達(dá)式 /(?:foo){1,2}/。如果表達(dá)式是 /foo{1,2}/,{1,2}將只對(duì) ‘foo' 的最后一個(gè)字符 'o‘ 生效。如果使用非捕獲括號(hào),則{1,2}會(huì)匹配整個(gè) ‘foo' 單詞。
x(?=y), x(?!y), x|y
x(?=y):匹配'x'僅僅當(dāng)'x'后面跟著'y';
x(?!y):匹配'x'僅僅當(dāng)'x'后面不跟著'y';
x|y: 匹配x或y
這兩種匹配的結(jié)果都不包含y
例子:
'JackSprat'.match(/Jack(?=Sprat)/) // ["Jack", index: 0, input: "JackSprat"]
'JackWprat'.match(/Jack(?=Sprat)/) // null
'JackWprat'.match(/Jack(?=Sprat|Wprat)/) // ["Jack", index: 0, input: "JackWprat"]
/\d+(?!\.)/.exec("3.141") // ["141", index: 2, input: "3.141"]
{n}, {n,m}:
{n}:匹配了前面一個(gè)字符剛好發(fā)生了n次;
{n,m}:匹配前面的字符至少n次,最多m次。如果 n 或者 m 的值是0, 這個(gè)值被忽略;
例子:
/a{2}/.exec('candy') // null
/a{2}/.exec('caandy') // ["aa", index: 1, input: "caandy"]
/a{2}/.exec('caaandy') // ["aa", index: 1, input: "caaandy"]
/a{1,3}/.exec('candy') // ["a", index: 1, input: "candy"]
/a{1,3}/.exec('caandy') // ["aa", index: 1, input: "caandy"]
/a{1,3}/.exec('caaandy') // ["aaa", index: 1, input: "caaandy"]
/a{1,3}/.exec('caaaandy') // ["aaa", index: 1, input: "caaaandy"]
[xyz], [^xyz]
[xyz]:一個(gè)字符集合。匹配方括號(hào)的中任意字符;
[^xyz]:一個(gè)反向字符集。匹配任何沒(méi)有包含在方括號(hào)中的字符;
這兩種匹配都可以使用破折號(hào)(-)來(lái)指定一個(gè)字符范圍,特殊符號(hào)在字符集中沒(méi)有了特殊意義。
例:
function escapeRegExp(string){
return string.replace(/([.*+?^=!:${}()|[\]\/\\])/g, "\\$");
//$表示整個(gè)被匹配的字符串
}
例子中的.*+?^=!:${}()都表示字面量,并沒(méi)有特殊意義。
其他
\b:匹配一個(gè)詞的邊界。一個(gè)匹配的詞的邊界并不包含在匹配的內(nèi)容中。換句話說(shuō),一個(gè)匹配的詞的邊界的內(nèi)容的長(zhǎng)度是0;
\B: 匹配一個(gè)非單詞邊界;
例子:
/\bm/.exec('moon') // ["m", index: 0, input: "moon"]
/\bm/.exec('san moon') // ["m", index: 4, input: "san moon"]
/oo\b/.exec('moon') // null
/\B../.exec('noonday') // ["oo", index: 1, input: "noonday"]
/y\B../.exec('possibly yesterday') // /y\B../.exec('possibly yesterday')
\d:匹配一個(gè)數(shù)字,等價(jià)于[0-9];
\D:匹配一個(gè)非數(shù)字字符,等價(jià)于[^0-9];
\f:匹配一個(gè)換頁(yè)符 (U+000C);
\n:匹配一個(gè)換行符 (U+000A);
\r:匹配一個(gè)回車符 (U+000D);
\s:匹配一個(gè)空白字符,包括空格、制表符、換頁(yè)符和換行符,等價(jià)于[ \f\n\r\t\v\u00a0\u1680\u180e\u2000-\u200a\u2028\u2029\u202f\u205f\u3000\ufeff];
\S:匹配一個(gè)非空白字符,等價(jià)于[^ \f\n\r\t\v\u00a0\u1680\u180e\u2000-\u200a\u2028\u2029\u202f\u205f\u3000\ufeff];
\w:匹配一個(gè)單字字符(字母、數(shù)字或者下劃線),等價(jià)于[A-Za-z0-9_];
\W:匹配一個(gè)非單字字符,等價(jià)于[^A-Za-z0-9_];
正則表達(dá)式標(biāo)志
g:全局搜索;
i:不區(qū)分大小寫(xiě);
m:多行搜索;
正則表達(dá)式使用
RegExp有exec()和test()方法;
exec匹配的結(jié)果為:匹配結(jié)果、捕獲結(jié)果,index和input。
test匹配的結(jié)果為true或false,效率比exec要高。
String有match(),replace(),search(),split()方法;
match匹配的結(jié)果同RegExp的exec,replace根據(jù)正則表達(dá)式替換,search查找所以位置,split根據(jù)正則表達(dá)式分割字符串。
其中,當(dāng)replace有function時(shí),參數(shù)說(shuō)明如下:
* 匹配項(xiàng)
* 記憶項(xiàng)(括號(hào)里面的項(xiàng))
* ...
* 匹配的index
* input輸入項(xiàng)
以上所述是小編給大家介紹的js中的正則表達(dá)式,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
您可能感興趣的文章:- JS正則表達(dá)式一條龍講解(從原理和語(yǔ)法到JS正則)
- JS中正則表達(dá)式全局匹配模式 /g用法詳解
- JS中使用正則表達(dá)式g模式和非g模式的區(qū)別
- js中string之正則表達(dá)式replace方法詳解
- 一個(gè)容易犯錯(cuò)的js手機(jī)號(hào)碼驗(yàn)證正則表達(dá)式(推薦)
- js中使用正則表達(dá)式查找字母和數(shù)字的方法
- JS正則表達(dá)式驗(yàn)證密碼格式的集中情況總結(jié)
- JS 密碼強(qiáng)度校驗(yàn)的正則表達(dá)式(簡(jiǎn)單且好用)
- JavaScript正則表達(dá)式替換字符串中圖片地址(img src)的方法