摘要:需要特別注意的是,如果使用方法生成正則對(duì)象,轉(zhuǎn)義需要使用兩個(gè)斜杠,因?yàn)樽址畠?nèi)部會(huì)先轉(zhuǎn)義一次。匹配一個(gè)以?xún)晌皇M(jìn)制數(shù)表示的字符。相比之下,點(diǎn)號(hào)作為元字符是不包括換行符的。星號(hào)表示某個(gè)模式出現(xiàn)次或多次,等同于。
匹配規(guī)則
字面量字符和元字符
轉(zhuǎn)義符
特殊字符
字符類(lèi)
預(yù)定義模式
重復(fù)類(lèi)
量詞符
貪婪模式
修飾符
組匹配
1.匹配規(guī)則
2.字面量字符和元字符
除了字面量字符以外,還有一部分字符有特殊含義,不代表字面的意思/abc/
(1)點(diǎn)字符(.)
點(diǎn)字符(.)匹配除回車(chē)(r)、換行(n) 、行分隔符(u2028)和段分隔符(u2029)以外的所有字符
(2)位置字符
^ 表示字符串的開(kāi)始位置
$ 表示字符串的結(jié)束位置
(3)選擇符(|)
豎線符號(hào)(|)在正則表達(dá)式中表示“或關(guān)系”(OR),即cat|dog表示匹配cat或dog
使用原括號(hào)()
/a( |t)b/.test("atb") // true
上面代碼指的是,a和b之間有一個(gè)空格或者一個(gè)制表符。
3.轉(zhuǎn)義符
正則表達(dá)式中那些有特殊含義的元字符
反斜杠轉(zhuǎn)義的,一共有12個(gè)字符:^、.、[、$、(、)、|、*、+、?、{和。
需要特別注意的是,如果使用RegExp方法生成正則對(duì)象,轉(zhuǎn)義需要使用兩個(gè)斜杠,因?yàn)樽址畠?nèi)部會(huì)先轉(zhuǎn)義一次。
4.特殊字符
正則表達(dá)式對(duì)一些不能打印的特殊字符,提供了表達(dá)方法。
cX 表示Ctrl-[X],其中的X是A-Z之中任一個(gè)英文字母,用來(lái)匹配控制字符。
[b] 匹配退格鍵(U+0008),不要與b混淆。
n 匹配換行鍵。
r 匹配回車(chē)鍵。
t 匹配制表符 tab(U+0009)。
v 匹配垂直制表符(U+000B)。
f 匹配換頁(yè)符(U+000C)。
0 匹配null字符(U+0000)。
xhh 匹配一個(gè)以?xún)晌皇M(jìn)制數(shù)(x00-xFF)表示的字符。
uhhhh 匹配一個(gè)以四位十六進(jìn)制數(shù)(u0000-uFFFF)表示的 Unicode 字符。
5.字符類(lèi)[]
(1)脫字符(^)
1表示除了x、y、z之外都可以匹配。
如果方括號(hào)內(nèi)沒(méi)有其他字符,即只有[^],就表示匹配一切字符,其中包括換行符。相比之下,點(diǎn)號(hào)作為元字符(.)是不包括換行符的。
var s = "Please yesnmake my day!";
s.match(/yes.*day/) // null
s.match(/yes[^]*day/) // [ "yesnmake my
注意,脫字符只有在字符類(lèi)的第一個(gè)位置才有特殊含義,否則就是字面含義。
(2)連字符(-)
表示字符的連續(xù)范圍。比如,[abc]可以寫(xiě)成[a-c],
最后一個(gè)字符類(lèi)[1-31],不代表1到31,只代表1到3。
另外,不要過(guò)分使用連字符,設(shè)定一個(gè)很大的范圍,否則很可能選中意料之外的字符。最典型的例子就是[A-z],表面上它是選中從大寫(xiě)的A到小寫(xiě)的z之間52個(gè)字母,但是由于在 ASCII 編碼之中,大寫(xiě)字母與小寫(xiě)字母之間還有其他字符,結(jié)果就會(huì)出現(xiàn)意料之外的結(jié)果。
/[A-z]/.test("") // true
6.預(yù)定義模式
預(yù)定義模式指的是某些常見(jiàn)模式的簡(jiǎn)寫(xiě)方式。
d 匹配0-9之間的任一數(shù)字,相當(dāng)于[0-9]。
D 匹配所有0-9以外的字符,相當(dāng)于2。
w 匹配任意的字母、數(shù)字和下劃線,相當(dāng)于[A-Za-z0-9_]。
W 除所有字母、數(shù)字和下劃線以外的字符,相當(dāng)于3。
s 匹配空格(包括換行符、制表符、空格符等),相等于[ trnvf]。
S 匹配非空格的字符,相當(dāng)于4。
b 匹配詞的邊界。
B 匹配非詞邊界,即在詞的內(nèi)部
// s 的例子
/sw*/.exec("hello world") // [" world"]
// b 的例子
/bworld/.test("hello world") // true
/bworld/.test("hello-world") // true
/bworld/.test("helloworld") // false
// B 的例子
/Bworld/.test("hello-world") // false
/Bworld/.test("helloworld") // true
上面代碼中,s表示空格,所以匹配結(jié)果會(huì)包括空格。b表示詞的邊界,所以world的詞首必須獨(dú)立(詞尾是否獨(dú)立未指定),才會(huì)匹配。同理,B表示非詞的邊界,只有world的詞首不獨(dú)立,才會(huì)匹配
通常,正則表達(dá)式遇到換行符(n)就會(huì)停止匹配。
var html = "Hellonworld!";
/.*/.exec(html)[0]
// "Hello"
上面代碼中,字符串html包含一個(gè)換行符,結(jié)果點(diǎn)字符(.)不匹配換行符,導(dǎo)致匹配結(jié)果可能不符合原意。這時(shí)使用s字符類(lèi),就能包括換行符。
var html = "Hellonworld!";
/[Ss]*/.exec(html)[0]
// "Hellonworld!"
上面代碼中,[Ss]指代一切字符
7.重復(fù)類(lèi)
使用大括號(hào)({})表示。{n}表示恰好重復(fù)n次,{n,}表示至少重復(fù)n次,{n,m}表示重復(fù)不少于n次,不多于m次。
/lo{2}k/.test("look") // true
/lo{2,5}k/.test("looook") // true
8.量詞符
? 問(wèn)號(hào)表示某個(gè)模式出現(xiàn)0次或1次,等同于{0, 1}。
星號(hào)表示某個(gè)模式出現(xiàn)0次或多次,等同于{0,}。
加號(hào)表示某個(gè)模式出現(xiàn)1次或多次,等同于{1,}
// t 出現(xiàn)0次或1次
/t?est/.test("test") // true
/t?est/.test("est") // true
// t 出現(xiàn)1次或多次
/t+est/.test("test") // true
/t+est/.test("ttest") // true
/t+est/.test("est") // false
// t 出現(xiàn)0次或多次
/t*est/.test("test") // true
/t*est/.test("ttest") // true
/t*est/.test("tttest") // true
/t*est/.test("est") // true
9.貪婪模式
默認(rèn)情況有多少匹配多少。+多+1個(gè) 非貪婪+10?0
var s = "aaa";
s.match(/a+/) // ["aaa"]
上面代碼中,模式是/a+/,表示匹配1個(gè)a或多個(gè)a,那么到底會(huì)匹配幾個(gè)a呢?因?yàn)槟J(rèn)是貪婪模式,會(huì)一直匹配到字符a不出現(xiàn)為止,所以匹配結(jié)果是3個(gè)a。
貪婪模式改為非貪婪模式
除了非貪婪模式的加號(hào),還有非貪婪模式的星號(hào)(*)和非貪婪模式的問(wèn)號(hào)(?)。
var s = "aaa";
s.match(/a+?/) // ["a"]
+?:表示某個(gè)模式出現(xiàn)1次或多次,匹配時(shí)采用非貪婪模式。
*?:表示某個(gè)模式出現(xiàn)0次或多次,匹配時(shí)采用非貪婪模式。
??:表格某個(gè)模式出現(xiàn)0次或1次,匹配時(shí)采用非貪婪模式
"abb".match(/ab*b/) // ["abb"]
"abb".match(/ab*?b/) // ["ab"]
"abb".match(/ab?b/) // ["abb"]
"abb".match(/ab??b/) // ["ab"]
10.修飾符
修飾符(modifier)表示模式的附加規(guī)則,放在正則模式的最尾部。
(1)g
默認(rèn)只匹配一次,加g多次,主要用于搜索和替換
var regex = /b/;
var str = "abba";
regex.test(str); // true
regex.test(str); // true
regex.test(str); // true
上面代碼中,正則模式不含g修飾符,每次都是從字符串頭部開(kāi)始匹配。所以,連續(xù)做了三次匹配,都返回true。
var regex = /b/g;
var str = "abba";
regex.test(str); // true
regex.test(str); // true
regex.test(str); // false
上面代碼中,正則模式含有g(shù)修飾符,每次都是從上一次匹配成功處,開(kāi)始向后匹配。因?yàn)樽址產(chǎn)bba只有兩個(gè)b,所以前兩次匹配結(jié)果為true,第三次匹配結(jié)果為false
(2)i
忽略大小寫(xiě)
(3)m
m修飾符表示多行模式(multiline),會(huì)修改^和$的行為。默認(rèn)情況下(即不加m修飾符時(shí)),^和$匹配字符串的開(kāi)始處和結(jié)尾處,加上m修飾符以后,^和$還會(huì)匹配行首和行尾,即^和$會(huì)識(shí)別換行符(n)
/^b/m.test("anb") // true
上面代碼要求匹配行首的b,如果不加m修飾符,就相當(dāng)于b只能處在字符串的開(kāi)始處。加上m修飾符以后,換行符n也會(huì)被認(rèn)為是一行的開(kāi)始
11.組匹配
(1)概述
正則表達(dá)式的括號(hào)表示分組匹配,括號(hào)中的模式可以用來(lái)匹配分組的內(nèi)容
1.1/fred+/.test("fredd") // true
/(fred)+/.test("fredfred") // true
上面代碼中,第一個(gè)模式?jīng)]有括號(hào),結(jié)果+只表示重復(fù)字母d,第二個(gè)模式有括號(hào),結(jié)果+就表示匹配fred這個(gè)詞
1.2var m = "abcabc".match(/(.)b(.)/);
m
// ["abc", "a", "c"]
上面代碼中,正則表達(dá)式/(.)b(.)/一共使用兩個(gè)括號(hào),第一個(gè)括號(hào)捕獲a,第二個(gè)括號(hào)捕獲c。
1.3注意,使用組匹配時(shí),不宜同時(shí)使用g修飾符,否則match方法不會(huì)捕獲分組的內(nèi)容。
var m = "abcabc".match(/(.)b(.)/g);
m // ["abc", "abc"]
1.4必須使用正則表達(dá)式的exec方法,配合循環(huán),才能讀到每一輪匹配的組捕獲。
var str = "abcabc";
var reg = /(.)b(.)/g;
while (true) {
var result = reg.exec(str);
if (!result) break;
console.log(result);
}
// ["abc", "a", "c"]
// ["abc", "a", "c"]
1.4正則表達(dá)式內(nèi)部,還可以用n引用括號(hào)匹配的內(nèi)容,n是從1開(kāi)始的自然數(shù),表示對(duì)應(yīng)順序的括號(hào)。
/(.)b(.)1b2/.test("abcabc")
// true
上面的代碼中,1表示第一個(gè)括號(hào)匹配的內(nèi)容(即a),2表示第二個(gè)括號(hào)匹配的內(nèi)容(即c)
1.5下面是另外一個(gè)例子。
/y(..)(.)21/.test("yabccab") // true
括號(hào)還可以嵌套。
/y((..)2)1/.test("yabababab") // true
上面代碼中,1指向外層括號(hào),2指向內(nèi)層括號(hào)
1.6一個(gè)匹配網(wǎng)頁(yè)標(biāo)簽的例子。
var tagName = /<(5+)>6*1>/;
tagName.exec("bold")[1]
// "b"
上面代碼中,圓括號(hào)匹配尖括號(hào)之中的標(biāo)簽,而1就表示對(duì)應(yīng)的閉合標(biāo)簽。
上面代碼略加修改,就能捕獲帶有屬性的標(biāo)簽。
var html = "Helloworld";
var tag = /<(w+)(5)>(.?)1>/g;
var match = tag.exec(html);
match[1] // "b"
match[2] // " class="hello""
match[3] // "Hello"
match = tag.exec(html);
match[1] // "i"
match[2] // ""
match[3] // "world"
(2)非捕獲組
(?:x)稱(chēng)為非捕獲組(Non-capturing group),表示不返回該組匹配的內(nèi)容,即匹配的結(jié)果中不計(jì)入這個(gè)括號(hào)。
非捕獲組的作用請(qǐng)考慮這樣一個(gè)場(chǎng)景,假定需要匹配foo或者foofoo,正則表達(dá)式就應(yīng)該寫(xiě)成/(foo){1, 2}/,但是這樣會(huì)占用一個(gè)組匹配。這時(shí),就可以使用非捕獲組,將正則表達(dá)式改為/(?:foo){1, 2}/,它的作用與前一個(gè)正則是一樣的,但是不會(huì)多帶帶輸出括號(hào)內(nèi)部的內(nèi)容。
請(qǐng)看下面的例子。
var m = "abc".match(/(?:.)b(.)/);
m // ["abc", "c"]
上面代碼中的模式,一共使用了兩個(gè)括號(hào)。其中第一個(gè)括號(hào)是非捕獲組,所以最后返回的結(jié)果中沒(méi)有第一個(gè)括號(hào),只有第二個(gè)括號(hào)匹配的內(nèi)容。
下面是用來(lái)分解網(wǎng)址的正則表達(dá)式。
// 正常匹配
var url = /(http|ftp)://(7+)(/8*)?/;
url.exec("http://google.com/");
// ["http://google.com/", "http", "google.com", "/"]
// 非捕獲組匹配
var url = /(?:http|ftp)://(9+)(/10*)?/;
url.exec("http://google.com/");
// ["http://google.com/", "google.com", "/"]
上面的代碼中,前一個(gè)正則表達(dá)式是正常匹配,第一個(gè)括號(hào)返回網(wǎng)絡(luò)協(xié)議;后一個(gè)正則表達(dá)式是非捕獲匹配,返回結(jié)果中不包括網(wǎng)絡(luò)協(xié)議。
(3)先行斷言
x(?=y)稱(chēng)為先行斷言(Positive look-ahead),x只有在y前面才匹配,y不會(huì)被計(jì)入返回結(jié)果。比如,要匹配后面跟著百分號(hào)的數(shù)字,可以寫(xiě)成/d+(?=%)/。
“先行斷言”中,括號(hào)里的部分是不會(huì)返回的。
var m = "abc".match(/b(?=c)/);
m // ["b"]
上面的代碼使用了先行斷言,b在c前面所以被匹配,但是括號(hào)對(duì)應(yīng)的c不會(huì)被返回。
(4)先行否定斷言
x(?!y)稱(chēng)為先行否定斷言(Negative look-ahead),x只有不在y前面才匹配,y不會(huì)被計(jì)入返回結(jié)果。比如,要匹配后面跟的不是百分號(hào)的數(shù)字,就要寫(xiě)成/d+(?!%)/。
/d+(?!.)/.exec("3.14")
// ["14"]
上面代碼中,正則表達(dá)式指定,只有不在小數(shù)點(diǎn)前面的數(shù)字才會(huì)被匹配,因此返回的結(jié)果就是14。
“先行否定斷言”中,括號(hào)里的部分是不會(huì)返回的。
var m = "abd".match(/b(?!c)/);
m // ["b"]
上面的代碼使用了先行否定斷言,b不在c前面所以被匹配,而且括號(hào)對(duì)應(yīng)的d不會(huì)被返回。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/105988.html
摘要:前一篇淺入正則一了解了實(shí)例化一個(gè)對(duì)象的原型方法的對(duì)象屬性這些基礎(chǔ),大致知道正則怎么用,這一篇主要想了解一下正則怎么寫(xiě)。 with (javascript) 前一篇淺入正則(一)了解了實(shí)例化一個(gè)RegExp對(duì)象、RegExp的原型方法、RegExp的對(duì)象屬性這些基礎(chǔ),大致知道正則怎么用,這一篇主要想了解一下正則怎么寫(xiě)。 元字符 元字符表隨便就查得到,但這是會(huì)寫(xiě)正則最重要的基礎(chǔ),這里簡(jiǎn)單分...
摘要:正則表達(dá)式是由普通字符例如字符到以及特殊字符稱(chēng)為元字符組成的文字模式。方法參數(shù)一個(gè)正則表達(dá)式對(duì)象。如果正則表達(dá)式?jīng)]有標(biāo)志,則會(huì)返回和相同的結(jié)果。其被視為一整個(gè)字符串,而不是一個(gè)正則表達(dá)式。 正則表達(dá)式 正則表達(dá)式(Regular Expression)是一種文本模式,包括普通字符(例如,a 到 z 之間的字母)和特殊字符(稱(chēng)為元字符)。正則表達(dá)式使用單個(gè)字符串來(lái)描述、匹配一系列匹配某個(gè)...
摘要:構(gòu)造函數(shù)參數(shù)無(wú)參數(shù)默認(rèn)當(dāng)天的日期一個(gè)用于表現(xiàn)日期的字符串分開(kāi)傳遞的日月時(shí)間等值一個(gè)值更精確的是向構(gòu)造器傳遞一些具體的數(shù)值年份月份從月月日期從到時(shí)數(shù)從到分鐘從到秒鐘從到毫秒數(shù)從到需要注意的是,如果所傳遞的值超過(guò)了被允許的范圍,對(duì)象會(huì)自行啟動(dòng)溢 github Date() 構(gòu)造函數(shù) 參數(shù): 無(wú)參數(shù)(默認(rèn)當(dāng)天的日期) 一個(gè)用于表現(xiàn)日期的字符串 分開(kāi)傳遞的日、月、時(shí)間等值 一個(gè) timest...
摘要:操作符還有可能是設(shè)計(jì)中最大缺陷,因?yàn)樗鼛缀跏峭耆茡p的。由于用法與調(diào)用函數(shù)的語(yǔ)法相似,因此常被誤以為是函數(shù)調(diào)用,實(shí)際上并不存在名為的函數(shù),只是一個(gè)操作符而已。而列則表示對(duì)象內(nèi)部的屬性。屬性文檔中明確地給出了獲得屬性的途徑,就是使用。 typeof 操作符(還有 instanceof)可能是 Javascript 設(shè)計(jì)中最大缺陷,因?yàn)樗鼛缀跏峭耆茡p的。由于 typeof 用法與調(diào)用函數(shù)...
摘要:方法用于從原字符串取出子字符串并返回,不改變?cè)址K牡谝粋€(gè)參數(shù)表示子字符串的開(kāi)始位置,第二個(gè)位置表示結(jié)束位置返回結(jié)果不含該位置方法按照給定規(guī)則分割字符串,返回一個(gè)由分割出來(lái)的子字符串組成的數(shù)組。 正則表達(dá)式 正則表達(dá)式 Regular Expression 是一種表達(dá)文本模式的方法 類(lèi)似字符串的模板 通常用來(lái)按照給定模式匹配文本 新建正則表達(dá)式有兩種方式:字面量方式 以...
摘要:語(yǔ)法參數(shù)必填項(xiàng),字符串或正則表達(dá)式,該參數(shù)指定的地方分割可選該參數(shù)指定返回的數(shù)組的最大長(zhǎng)度,如果設(shè)置了該參數(shù),返回的子字符串不會(huì)多于這個(gè)參數(shù)指定的數(shù)組。該數(shù)組通過(guò)在指定的邊界處將字符串分割成子字符串。把正則表達(dá)式拆分成小表達(dá)式。 正則表達(dá)式是什么 RegExp 對(duì)象表示正則表達(dá)式,它是對(duì)字符串執(zhí)行模式匹配的強(qiáng)大工具。 為什么使用正則表達(dá)式 測(cè)試字符串內(nèi)的模式。例如,可以測(cè)試輸入字符串...
閱讀 3880·2021-09-23 11:51
閱讀 3067·2021-09-22 15:59
閱讀 868·2021-09-09 11:37
閱讀 2070·2021-09-08 09:45
閱讀 1267·2019-08-30 15:54
閱讀 2065·2019-08-30 15:53
閱讀 492·2019-08-29 12:12
閱讀 3290·2019-08-29 11:15