麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 編程 > regex > 正文

深入淺析js中的正則表達(dá)式

2020-01-20 22:01:36
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

閱讀目錄

  • 正則表達(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, "http://$&");   //$&表示整個(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è)回車(chē)符 (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)網(wǎng)站的支持!

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 在线日韩av电影 | 日韩在线播放第一页 | 一本色道久久综合狠狠躁篇适合什么人看 | 久久精品99国产国产精 | 亚洲精中文字幕二区三区 | 欧美 亚洲 视频 | 精品国产一区三区 | 国产精品久久久久久影院8一贰佰 | 久久久久久久久久久久久久久久久久 | 538任你躁在线精品视频网站 | 久久精品一区二区三区不卡牛牛 | 久久国产成人精品国产成人亚洲 | 蜜桃成品人免费视频 | 精品国产一区二区久久 | 精品国产一区二区三区在线观看 | 人人做人人看 | 日本中文字幕电影在线观看 | 亚洲第一页在线观看 | 欧美三日本三级少妇三级99观看视频 | 国产99久久久久久免费看 | 欧美精品国产综合久久 | 日韩精品一区二 | 免费一级欧美大片视频 | 黄色特级毛片 | 国产一区精品视频 | 国产一区精品视频 | 国产免费一区二区三区 | 西川av在线一区二区三区 | 久久久日韩精品一区二区三区 | 一级外国毛片 | 久久精品国产99久久久古代 | www.9191.com| 成人一级黄色片 | 久久国产成人精品国产成人亚洲 | www.guochanav.com| 精品国内视频 | 久久精品亚洲精品国产欧美kt∨ | 日韩 欧美 中文 | 午夜热门福利 | 久久国产精品免费视频 | 国产艳妇av视国产精选av一区 |