亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Regex > 正文

深入淺析js中的正則表達式

2020-03-16 20:53:52
字體:
來源:轉載
供稿:網友

閱讀目錄

  • 正則表達式的創建
  • 正則表達式中的特殊字符
  • / (反斜杠)
  • ^
  • $
  • *,  +,  .(小數點)
  • ? (問號)
  • (x)
  • (?:x)
  • x(?=y), x(?!y), x|y
  • {n}, {n,m}:
  • [xyz], [^xyz]
  • 其他
  • 正則表達式標志
  • 正則表達式使用

很多時候多會被正則表達式搞的暈頭轉向,最近抽出時間對正則表達式進行了系統的學習,整理如下:

正則表達式的創建

兩種方法,一種是直接寫,由包含在斜杠之間的模式組成;另一種是調用RegExp對象的構造函數。

兩種方法的創建代碼如下:

// 直接創建const regex1 = /ab+c/;const regex2 = /^[a-zA-Z]+[0-9]*/W?_$/gi;// 調用構造函數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');

可以看出,調用RegExp構造函數創建正則表達式時,第一個參數可以是字符串,也可以是直接創建的正則表達式。

需要注意的是:RegExp實例繼承的toLocaleString()和toString)()方法都會返回正則表達式的字面量,與創建正則表達式的方式無關

例如:

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/-/.]*)/' 

正則表達式中的特殊字符

/ (反斜杠)

1.在非特殊字符前加反斜杠表示下一個字符是特殊的;

2.將其后的特殊字符轉譯為字面量;

注意:在使用RegExp構造函數時要將/轉譯,因為/在字符串里也是轉譯字符

^

1.匹配輸入的開始;

2.在[]中的第一位時表示反向字符集;

例子:

/^A/.exec('an A')    // null/^A/.exec('An E')    // ["A", index: 0, input: "An E"]

$

 

匹配輸入的結束

/t$/.exec('eater')    // null/t$/.exec('eat')     // ["t", index: 2, input: "eat"]*, +, .(小數點) 

*:匹配前一個表達式0次或多次。等價于 {0,};

+:匹配前面一個表達式1次或者多次。等價于 {1,};

.:

匹配除換行符之外的任何單個字符;

? (問號)

1.匹配前面一個表達式0次或者1次。等價于 {0,1};

2.如果緊跟在任何量詞 * + ? {} 的后面,將會使量詞變為非貪婪的(匹配盡量少的字符),和缺省使用的貪婪模式正好相反;

3.運用于先行斷言

例子:

//d+/.exec('123abc')       // ["123", index: 0, input: "123abc"]//d+?/.exec('123abc')      // ["1", index: 0, input: "123abc"]

(x)

匹配 'x' 并且記住匹配項,括號表示捕獲括號;

例子:

/(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" 中前兩個單詞。模式中的 /1 和 /2 匹配字符串的后兩個單詞。

注意:/1、/2、/n 是用在正則表達式的匹配環節,在正則表達式的替換環節,則要使用像 $1、$2、$n 這樣的語法。例如,'bar foo'.replace( /(...) (...)/, '$2 $1' )。

(?:x)

匹配 'x' 但是不記住匹配項,這種叫作非捕獲括號;

例子:

'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"]

使用場景:示例表達式 /(?:foo){1,2}/。如果表達式是 /foo{1,2}/,{1,2}將只對 ‘foo' 的最后一個字符 'o‘ 生效。如果使用非捕獲括號,則{1,2}會匹配整個 ‘foo' 單詞。

x(?=y), x(?!y), x|y

x(?=y):匹配'x'僅僅當'x'后面跟著'y';

x(?!y):匹配'x'僅僅當'x'后面不跟著'y';

x|y: 匹配x或y

這兩種匹配的結果都不包含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}:匹配了前面一個字符剛好發生了n次;

{n,m}:匹配前面的字符至少n次,最多m次。如果 n 或者 m 的值是0, 這個值被忽略;

例子:

  /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]:一個字符集合。匹配方括號的中任意字符;

[^xyz]:一個反向字符集。匹配任何沒有包含在方括號中的字符;

這兩種匹配都可以使用破折號(-)來指定一個字符范圍,特殊符號在字符集中沒有了特殊意義。

例:

function escapeRegExp(string){  return string.replace(/([.*+?^=!:${}()|[/]////])/g, "//$&");   //$&表示整個被匹配的字符串}

例子中的.*+?^=!:${}()都表示字面量,并沒有特殊意義。

其他

/b:匹配一個詞的邊界。一個匹配的詞的邊界并不包含在匹配的內容中。換句話說,一個匹配的詞的邊界的內容的長度是0;

/B: 匹配一個非單詞邊界;

例子:

  //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:匹配一個數字,等價于[0-9];

/D:匹配一個非數字字符,等價于[^0-9];

/f:匹配一個換頁符 (U+000C);

/n:匹配一個換行符 (U+000A);

/r:匹配一個回車符 (U+000D);

/s:匹配一個空白字符,包括空格、制表符、換頁符和換行符,等價于[ /f/n/r/t/v/u00a0/u1680/u180e/u2000-/u200a/u2028/u2029/u202f/u205f/u3000/ufeff];

/S:匹配一個非空白字符,等價于[^ /f/n/r/t/v/u00a0/u1680/u180e/u2000-/u200a/u2028/u2029/u202f/u205f/u3000/ufeff];

/w:匹配一個單字字符(字母、數字或者下劃線),等價于[A-Za-z0-9_];

/W:匹配一個非單字字符,等價于[^A-Za-z0-9_];

正則表達式標志

g:全局搜索;

i:不區分大小寫;

m:多行搜索;

正則表達式使用

RegExp有exec()和test()方法;

exec匹配的結果為:匹配結果、捕獲結果,index和input。

test匹配的結果為true或false,效率比exec要高。

String有match(),replace(),search(),split()方法;

match匹配的結果同RegExp的exec,replace根據正則表達式替換,search查找所以位置,split根據正則表達式分割字符串。

其中,當replace有function時,參數說明如下:

* 匹配項
* 記憶項(括號里面的項)
* ...
* 匹配的index
* input輸入項

以上所述是小編給大家介紹的js中的正則表達式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VEVB武林網網站的支持!


注:相關教程知識閱讀請移步到正則表達式頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产视频久久久| 欧美激情2020午夜免费观看| 久久精品福利视频| 亚洲欧美另类自拍| 国产精品久久久久久久久影视| 亚洲国产精品va在线看黑人| 成人激情视频在线播放| 久久777国产线看观看精品| 国产区亚洲区欧美区| 日韩国产欧美精品一区二区三区| 最近2019年好看中文字幕视频| 成人国产在线视频| 国产精品视频色| 欧美成人激情在线| 日韩成人在线视频| 亚洲午夜性刺激影院| 欧美日韩在线视频首页| 亚洲精品免费av| 国产精品电影观看| 国产美女精品视频| 国产成人在线亚洲欧美| 亚洲欧美三级伦理| 国产精品免费福利| 92福利视频午夜1000合集在线观看| 欧美日韩美女在线观看| 久久99国产精品久久久久久久久| 国产精品视频一区国模私拍| 亚洲一二在线观看| 亚洲精品自拍偷拍| 日韩av电影在线免费播放| 98视频在线噜噜噜国产| 国产精品成久久久久三级| 色中色综合影院手机版在线观看| 中文字幕在线观看日韩| 欧美一区二区三区……| 国内精品中文字幕| 国产精品一区二区久久国产| 91精品在线观看视频| 日韩中文字幕免费视频| 91精品国产乱码久久久久久久久| 日韩中文字幕在线| 欧美精品成人91久久久久久久| 亚洲成人精品视频在线观看| 亚洲视频999| 国产视频久久久久| 亚洲精品一区二三区不卡| 欧美日韩一区二区在线播放| 在线激情影院一区| 久久激情五月丁香伊人| 亚洲视频在线免费看| 日韩的一区二区| 国产精品美女主播在线观看纯欲| 国产精品电影网| 国产91精品青草社区| 国内精品免费午夜毛片| 亚洲午夜色婷婷在线| 欧美野外猛男的大粗鳮| 国产精品流白浆视频| 国产精品九九九| 成人欧美一区二区三区在线| 日韩亚洲精品电影| 91精品啪aⅴ在线观看国产| 欧美日本中文字幕| 欧美裸体xxxx极品少妇软件| 精品呦交小u女在线| 国产精品在线看| 日韩电影免费观看在线| 国产在线观看91精品一区| 黑人巨大精品欧美一区二区| 欧美激情亚洲国产| 亚洲另类xxxx| 国产精品成久久久久三级| 久久伊人精品天天| 欧美俄罗斯性视频| 欧美日韩中文字幕在线视频| 久久精品99久久香蕉国产色戒| 亚洲精品www久久久| 亚洲欧美在线免费| 国产亚洲精品久久久| 精品香蕉一区二区三区| 97免费在线视频| 精品国产一区二区三区四区在线观看| 亚洲白虎美女被爆操| 91探花福利精品国产自产在线| 成人午夜激情免费视频| 欧美激情女人20p| 国产精品视频区1| 国内伊人久久久久久网站视频| 91日韩在线播放| 亚洲一区二区久久久久久久| 久久国产精品电影| 亚洲精品理论电影| 久久影视电视剧免费网站清宫辞电视| 国产精品入口日韩视频大尺度| 欧美精品成人在线| 亚洲综合第一页| 一区二区三区四区在线观看视频| 日韩精品视频观看| 亚洲色在线视频| 91精品视频在线| 亚洲国产成人久久综合| 亚洲一区二区自拍| 日韩美女福利视频| 亚洲欧美制服另类日韩| 国产拍精品一二三| 欧美人在线视频| 不卡av电影在线观看| 久久久久久久激情视频| 久久精品久久久久电影| 91禁外国网站| 九九久久综合网站| 在线性视频日韩欧美| 日韩一级裸体免费视频| 久久久久久久久国产精品| 国产成人福利视频| 亚洲国产高清自拍| 日韩精品电影网| 亚洲欧洲国产一区| 98精品国产高清在线xxxx天堂| 欧美大尺度激情区在线播放| 亚洲成人激情图| 亚洲xxxx妇黄裸体| 日韩中文第一页| 亚洲色图色老头| 亚洲色图狂野欧美| 国产精品亚洲片夜色在线| 国产亚洲一级高清| 51精品国产黑色丝袜高跟鞋| 97精品国产91久久久久久| 国产精品高潮呻吟视频| 亚洲精品久久久久久久久久久| 57pao成人永久免费视频| 日韩在线免费观看视频| 欧美成人亚洲成人日韩成人| 亚洲欧洲激情在线| 麻豆国产精品va在线观看不卡| 国产欧美精品一区二区| 久久久亚洲国产| 日韩电影免费观看中文字幕| 亚洲国产一区二区三区在线观看| 日韩精品视频观看| 国产精品久久久久久久7电影| 国产精品久久久久久av| 亚洲精品美女在线观看| 亚洲三级av在线| 中文字幕精品一区久久久久| 中文字幕日韩高清| 一级做a爰片久久毛片美女图片| 在线激情影院一区| 欧美日韩国产页| 92版电视剧仙鹤神针在线观看| 亚洲欧美在线免费| 尤物99国产成人精品视频| 亚洲精品一区av在线播放| 日韩欧美a级成人黄色| 国产精品69久久久久| 久久中文字幕一区| 国产精品色午夜在线观看| 精品一区二区三区四区| 日本成人免费在线| 亚洲精品自拍视频| 最新亚洲国产精品| 久久视频中文字幕| 国产一区二区三区在线观看视频|