成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Regexp對象二

VPointer / 1320人閱讀

摘要:需要特別注意的是,如果使用方法生成正則對象,轉(zhuǎn)義需要使用兩個斜杠,因為字符串內(nèi)部會先轉(zhuǎn)義一次。匹配一個以兩位十六進制數(shù)表示的字符。相比之下,點號作為元字符是不包括換行符的。星號表示某個模式出現(xiàn)次或多次,等同于。

匹配規(guī)則
字面量字符和元字符
轉(zhuǎn)義符
特殊字符
字符類
預(yù)定義模式
重復(fù)類
量詞符
貪婪模式
修飾符
組匹配

1.匹配規(guī)則
2.字面量字符和元字符
除了字面量字符以外,還有一部分字符有特殊含義,不代表字面的意思/abc/
(1)點字符(.)
點字符(.)匹配除回車(r)、換行(n) 、行分隔符(u2028)和段分隔符(u2029)以外的所有字符
(2)位置字符
^ 表示字符串的開始位置
$ 表示字符串的結(jié)束位置
(3)選擇符(|)
豎線符號(|)在正則表達式中表示“或關(guān)系”(OR),即cat|dog表示匹配cat或dog
使用原括號()
/a( |t)b/.test("atb") // true
上面代碼指的是,a和b之間有一個空格或者一個制表符。

3.轉(zhuǎn)義符
正則表達式中那些有特殊含義的元字符
反斜杠轉(zhuǎn)義的,一共有12個字符:^、.、[、$、(、)、|、*、+、?、{和。
需要特別注意的是,如果使用RegExp方法生成正則對象,轉(zhuǎn)義需要使用兩個斜杠,因為字符串內(nèi)部會先轉(zhuǎn)義一次。

4.特殊字符
正則表達式對一些不能打印的特殊字符,提供了表達方法。

cX 表示Ctrl-[X],其中的X是A-Z之中任一個英文字母,用來匹配控制字符。
[b] 匹配退格鍵(U+0008),不要與b混淆。
n 匹配換行鍵。
r 匹配回車鍵。
t 匹配制表符 tab(U+0009)。
v 匹配垂直制表符(U+000B)。
f 匹配換頁符(U+000C)。
0 匹配null字符(U+0000)。
xhh 匹配一個以兩位十六進制數(shù)(x00-xFF)表示的字符。
uhhhh 匹配一個以四位十六進制數(shù)(u0000-uFFFF)表示的 Unicode 字符。

5.字符類[]
(1)脫字符(^)
1表示除了x、y、z之外都可以匹配。

如果方括號內(nèi)沒有其他字符,即只有[^],就表示匹配一切字符,其中包括換行符。相比之下,點號作為元字符(.)是不包括換行符的。

var s = "Please yesnmake my day!";

s.match(/yes.*day/) // null
s.match(/yes[^]*day/) // [ "yesnmake my

注意,脫字符只有在字符類的第一個位置才有特殊含義,否則就是字面含義。
(2)連字符(-)

表示字符的連續(xù)范圍。比如,[abc]可以寫成[a-c],
最后一個字符類[1-31],不代表1到31,只代表1到3。

另外,不要過分使用連字符,設(shè)定一個很大的范圍,否則很可能選中意料之外的字符。最典型的例子就是[A-z],表面上它是選中從大寫的A到小寫的z之間52個字母,但是由于在 ASCII 編碼之中,大寫字母與小寫字母之間還有其他字符,結(jié)果就會出現(xiàn)意料之外的結(jié)果。

/[A-z]/.test("") // true

6.預(yù)定義模式
預(yù)定義模式指的是某些常見模式的簡寫方式。

d 匹配0-9之間的任一數(shù)字,相當于[0-9]。
D 匹配所有0-9以外的字符,相當于2。
w 匹配任意的字母、數(shù)字和下劃線,相當于[A-Za-z0-9_]。
W 除所有字母、數(shù)字和下劃線以外的字符,相當于3。
s 匹配空格(包括換行符、制表符、空格符等),相等于[ trnvf]。
S 匹配非空格的字符,相當于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é)果會包括空格。b表示詞的邊界,所以world的詞首必須獨立(詞尾是否獨立未指定),才會匹配。同理,B表示非詞的邊界,只有world的詞首不獨立,才會匹配

通常,正則表達式遇到換行符(n)就會停止匹配。

var html = "Hellonworld!";

/.*/.exec(html)[0]
// "Hello"
上面代碼中,字符串html包含一個換行符,結(jié)果點字符(.)不匹配換行符,導(dǎo)致匹配結(jié)果可能不符合原意。這時使用s字符類,就能包括換行符。

var html = "Hellonworld!";

/[Ss]*/.exec(html)[0]
// "Hellonworld!"
上面代碼中,[Ss]指代一切字符

7.重復(fù)類
使用大括號({})表示。{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.量詞符
? 問號表示某個模式出現(xiàn)0次或1次,等同于{0, 1}。

星號表示某個模式出現(xiàn)0次或多次,等同于{0,}。

加號表示某個模式出現(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.貪婪模式
默認情況有多少匹配多少。+多+1個 非貪婪+10?0

var s = "aaa";
s.match(/a+/) // ["aaa"]
上面代碼中,模式是/a+/,表示匹配1個a或多個a,那么到底會匹配幾個a呢?因為默認是貪婪模式,會一直匹配到字符a不出現(xiàn)為止,所以匹配結(jié)果是3個a。

貪婪模式改為非貪婪模式
除了非貪婪模式的加號,還有非貪婪模式的星號(*)和非貪婪模式的問號(?)。
var s = "aaa";
s.match(/a+?/) // ["a"]

+?:表示某個模式出現(xiàn)1次或多次,匹配時采用非貪婪模式。
*?:表示某個模式出現(xiàn)0次或多次,匹配時采用非貪婪模式。
??:表格某個模式出現(xiàn)0次或1次,匹配時采用非貪婪模式
"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
默認只匹配一次,加g多次,主要用于搜索和替換

var regex = /b/;
var str = "abba";

regex.test(str); // true
regex.test(str); // true
regex.test(str); // true
上面代碼中,正則模式不含g修飾符,每次都是從字符串頭部開始匹配。所以,連續(xù)做了三次匹配,都返回true。

var regex = /b/g;
var str = "abba";

regex.test(str); // true
regex.test(str); // true
regex.test(str); // false
上面代碼中,正則模式含有g(shù)修飾符,每次都是從上一次匹配成功處,開始向后匹配。因為字符串a(chǎn)bba只有兩個b,所以前兩次匹配結(jié)果為true,第三次匹配結(jié)果為false

(2)i
忽略大小寫

(3)m
m修飾符表示多行模式(multiline),會修改^和$的行為。默認情況下(即不加m修飾符時),^和$匹配字符串的開始處和結(jié)尾處,加上m修飾符以后,^和$還會匹配行首和行尾,即^和$會識別換行符(n)

/^b/m.test("anb") // true

上面代碼要求匹配行首的b,如果不加m修飾符,就相當于b只能處在字符串的開始處。加上m修飾符以后,換行符n也會被認為是一行的開始

11.組匹配
(1)概述
正則表達式的括號表示分組匹配,括號中的模式可以用來匹配分組的內(nèi)容

1.1/fred+/.test("fredd") // true
/(fred)+/.test("fredfred") // true
上面代碼中,第一個模式?jīng)]有括號,結(jié)果+只表示重復(fù)字母d,第二個模式有括號,結(jié)果+就表示匹配fred這個詞

1.2var m = "abcabc".match(/(.)b(.)/);
m
// ["abc", "a", "c"]
上面代碼中,正則表達式/(.)b(.)/一共使用兩個括號,第一個括號捕獲a,第二個括號捕獲c。

1.3注意,使用組匹配時,不宜同時使用g修飾符,否則match方法不會捕獲分組的內(nèi)容。

var m = "abcabc".match(/(.)b(.)/g);
m // ["abc", "abc"]

1.4必須使用正則表達式的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正則表達式內(nèi)部,還可以用n引用括號匹配的內(nèi)容,n是從1開始的自然數(shù),表示對應(yīng)順序的括號。

/(.)b(.)1b2/.test("abcabc")
// true
上面的代碼中,1表示第一個括號匹配的內(nèi)容(即a),2表示第二個括號匹配的內(nèi)容(即c)

1.5下面是另外一個例子。

/y(..)(.)21/.test("yabccab") // true
括號還可以嵌套。

/y((..)2)1/.test("yabababab") // true
上面代碼中,1指向外層括號,2指向內(nèi)層括號

1.6一個匹配網(wǎng)頁標簽的例子。

var tagName = /<(5+)>6*/;

tagName.exec("bold")[1]
// "b"
上面代碼中,圓括號匹配尖括號之中的標簽,而1就表示對應(yīng)的閉合標簽。

上面代碼略加修改,就能捕獲帶有屬性的標簽。

var html = "Helloworld";
var tag = /<(w+)(5)>(.?)/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)稱為非捕獲組(Non-capturing group),表示不返回該組匹配的內(nèi)容,即匹配的結(jié)果中不計入這個括號。

非捕獲組的作用請考慮這樣一個場景,假定需要匹配foo或者foofoo,正則表達式就應(yīng)該寫成/(foo){1, 2}/,但是這樣會占用一個組匹配。這時,就可以使用非捕獲組,將正則表達式改為/(?:foo){1, 2}/,它的作用與前一個正則是一樣的,但是不會多帶帶輸出括號內(nèi)部的內(nèi)容。

請看下面的例子。

var m = "abc".match(/(?:.)b(.)/);
m // ["abc", "c"]
上面代碼中的模式,一共使用了兩個括號。其中第一個括號是非捕獲組,所以最后返回的結(jié)果中沒有第一個括號,只有第二個括號匹配的內(nèi)容。

下面是用來分解網(wǎng)址的正則表達式。

// 正常匹配
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", "/"]
上面的代碼中,前一個正則表達式是正常匹配,第一個括號返回網(wǎng)絡(luò)協(xié)議;后一個正則表達式是非捕獲匹配,返回結(jié)果中不包括網(wǎng)絡(luò)協(xié)議。

(3)先行斷言

x(?=y)稱為先行斷言(Positive look-ahead),x只有在y前面才匹配,y不會被計入返回結(jié)果。比如,要匹配后面跟著百分號的數(shù)字,可以寫成/d+(?=%)/。

“先行斷言”中,括號里的部分是不會返回的。

var m = "abc".match(/b(?=c)/);
m // ["b"]
上面的代碼使用了先行斷言,b在c前面所以被匹配,但是括號對應(yīng)的c不會被返回。

(4)先行否定斷言

x(?!y)稱為先行否定斷言(Negative look-ahead),x只有不在y前面才匹配,y不會被計入返回結(jié)果。比如,要匹配后面跟的不是百分號的數(shù)字,就要寫成/d+(?!%)/。

/d+(?!.)/.exec("3.14")
// ["14"]
上面代碼中,正則表達式指定,只有不在小數(shù)點前面的數(shù)字才會被匹配,因此返回的結(jié)果就是14。

“先行否定斷言”中,括號里的部分是不會返回的。

var m = "abd".match(/b(?!c)/);
m // ["b"]
上面的代碼使用了先行否定斷言,b不在c前面所以被匹配,而且括號對應(yīng)的d不會被返回。

  • xyz ?

  • 0-9 ?

  • A-Za-z0-9_ ?

  • trnvf ?

  • > ?

  • < ?

  • /rn ?

  • rn ?

  • /rn ?

  • rn ?

  • 文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

    轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/105988.html

    相關(guān)文章

    • 淺入正則(

      摘要:前一篇淺入正則一了解了實例化一個對象的原型方法的對象屬性這些基礎(chǔ),大致知道正則怎么用,這一篇主要想了解一下正則怎么寫。 with (javascript) 前一篇淺入正則(一)了解了實例化一個RegExp對象、RegExp的原型方法、RegExp的對象屬性這些基礎(chǔ),大致知道正則怎么用,這一篇主要想了解一下正則怎么寫。 元字符 元字符表隨便就查得到,但這是會寫正則最重要的基礎(chǔ),這里簡單分...

      MRZYD 評論0 收藏0
    • JavaScript的正則表達式

      摘要:正則表達式是由普通字符例如字符到以及特殊字符稱為元字符組成的文字模式。方法參數(shù)一個正則表達式對象。如果正則表達式?jīng)]有標志,則會返回和相同的結(jié)果。其被視為一整個字符串,而不是一個正則表達式。 正則表達式 正則表達式(Regular Expression)是一種文本模式,包括普通字符(例如,a 到 z 之間的字母)和特殊字符(稱為元字符)。正則表達式使用單個字符串來描述、匹配一系列匹配某個...

      jsdt 評論0 收藏0
    • Date 對象

      摘要:構(gòu)造函數(shù)參數(shù)無參數(shù)默認當天的日期一個用于表現(xiàn)日期的字符串分開傳遞的日月時間等值一個值更精確的是向構(gòu)造器傳遞一些具體的數(shù)值年份月份從月月日期從到時數(shù)從到分鐘從到秒鐘從到毫秒數(shù)從到需要注意的是,如果所傳遞的值超過了被允許的范圍,對象會自行啟動溢 github Date() 構(gòu)造函數(shù) 參數(shù): 無參數(shù)(默認當天的日期) 一個用于表現(xiàn)日期的字符串 分開傳遞的日、月、時間等值 一個 timest...

      kgbook 評論0 收藏0
    • 細說 Javascript 類型篇() : typeof 操作符

      摘要:操作符還有可能是設(shè)計中最大缺陷,因為它幾乎是完全破損的。由于用法與調(diào)用函數(shù)的語法相似,因此常被誤以為是函數(shù)調(diào)用,實際上并不存在名為的函數(shù),只是一個操作符而已。而列則表示對象內(nèi)部的屬性。屬性文檔中明確地給出了獲得屬性的途徑,就是使用。 typeof 操作符(還有 instanceof)可能是 Javascript 設(shè)計中最大缺陷,因為它幾乎是完全破損的。由于 typeof 用法與調(diào)用函數(shù)...

      PAMPANG 評論0 收藏0
    • RegExp對象

      摘要:方法用于從原字符串取出子字符串并返回,不改變原字符串。它的第一個參數(shù)表示子字符串的開始位置,第二個位置表示結(jié)束位置返回結(jié)果不含該位置方法按照給定規(guī)則分割字符串,返回一個由分割出來的子字符串組成的數(shù)組。 正則表達式 正則表達式 Regular Expression 是一種表達文本模式的方法 類似字符串的模板 通常用來按照給定模式匹配文本 新建正則表達式有兩種方式:字面量方式 以...

      wangdai 評論0 收藏0
    • JavaScript必會技能——正則表達式

      摘要:語法參數(shù)必填項,字符串或正則表達式,該參數(shù)指定的地方分割可選該參數(shù)指定返回的數(shù)組的最大長度,如果設(shè)置了該參數(shù),返回的子字符串不會多于這個參數(shù)指定的數(shù)組。該數(shù)組通過在指定的邊界處將字符串分割成子字符串。把正則表達式拆分成小表達式。 正則表達式是什么 RegExp 對象表示正則表達式,它是對字符串執(zhí)行模式匹配的強大工具。 為什么使用正則表達式 測試字符串內(nèi)的模式。例如,可以測試輸入字符串...

      FrozenMap 評論0 收藏0

    發(fā)表評論

    0條評論

    最新活動
    閱讀需要支付1元查看
    <