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

資訊專欄INFORMATION COLUMN

正則表達式詳解 js

fredshare / 1397人閱讀

摘要:程序員的正則表達式,醫(yī)生的處方和道士的鬼畫符,都是利器。其實,正則表達式是一門語言,有自己獨特的語法,還擁有自己的解釋器。但是,如果正則表達式是動態(tài)的,是根據(jù)變量來定義的,那么,只能使用第二種構(gòu)造函數(shù)的方式。

前言

作為一個程序員,要出去裝逼,手中必備的技能就是正則表達式。程序員的正則表達式,醫(yī)生的處方和道士的鬼畫符,都是利器。

在js中,很多的場景需要去使用到它(畢竟,js剛剛誕生的時候,是用來做表單等驗證的)。其實,正則表達式是一門語言,有自己獨特的語法,還擁有自己的解釋器。但是,作為使用來說,我們只需要掌握它的語法,多多運用,才能熟練。其實,我想過很多種詳解表達式的方式,但是,似乎每種方式都有缺陷,因為正則表達式的語法需要記憶的部分比較多。最后,我覺得可以通過比較和分類的方式去記憶。如果你喜歡我的文章,歡迎評論,歡迎Star~。歡迎關(guān)注我的github博客

正文 創(chuàng)建

在正則表達式中,有兩種方式可以去創(chuàng)建正則表達式:

字面量

const reg = /abc/;

構(gòu)造函數(shù)

const reg = new RegExp("abc");

對于這兩種方式,如果正則表達式是靜態(tài)的,那么,使用第一種字面量的方式,性能會比較好。但是,如果正則表達式是動態(tài)的,是根據(jù)變量來定義的,那么,只能使用第二種構(gòu)造函數(shù)的方式。

語法

^ 和 $的對比

^:匹配字符串的行首。示例說明:

const reg = /^A/;

console.log(reg.test("Ant"));    //true
console.log(reg.test(" Ant"));       //false

$:匹配字符串的行尾。示例說明:
const reg = /t$/;

console.log(reg.test("eat"));       //true
console.log(reg.test("enter"));       //false

重復(fù)限定符(*、+、?、{n}、{n,}、{n, m})

*:匹配前一個字符0次或多次,(x >= 0)

const reg = /a*/;

console.log(reg.test("ba"));      //true
console.log(reg.test("b"));       //true
console.log(reg.test("baaa"));     //true

+:匹配前一個字符1次或多次,(x >= 1)

const reg = /a+/;

console.log(reg.test("ba"));    //true
console.log(reg.test("baaa"));    //true
console.log(reg.test("b"));     //false

?:匹配前一個字符的0次或1次,(x = 0 || x = 1)

const reg = /ba?/;

console.log(reg.exec("ba"));      //["ba"]
console.log(reg.exec("baaa"));      //["ba"]
console.log(reg.exec("b"));     //["b"]

注:這里只是指明了?字符的限定符方面的用法,它還可以控制貪婪模式和非貪婪模式(下文可見)

{n}: 匹配前一個字符n次,(x = n)

const reg = /ba{3}/;

console.log(reg.test("ba"));     //false
console.log(reg.test("baaa"));      //true
console.log(reg.test("b"));     //false

{n,}:匹配前一個字符n次或大于n次,(x >=n)

const reg = /ba{3,}/;

console.log(reg.test("ba"));     //false
console.log(reg.test("baaa"));      //true
console.log(reg.test("baaaa"));      //true
console.log(reg.test("b"));      //false

{n, m}:匹配前一個字符n次到m次之間,(n <= x <= m)

const reg = /ba{2,3}/;

console.log(reg.test("ba"));     //false
console.log(reg.test("baaa"));     //true
console.log(reg.test("baa"));     //true
console.log(reg.test("b"));      //false

元字符(. 、d、w、s、b)

. :匹配除換行符以外的所有字符

const reg = /b.?/;

console.log(reg.exec("ba"));     //["ba"]
console.log(reg.exec("bxaa"));      //["bx"]
console.log(reg.exec("bza"));     //["bz"]
console.log(reg.exec("b"));      //["b"]

d:匹配數(shù)字字符,與[0-9]一致(單詞記憶法 => 數(shù)字【digital】)

const reg = /bd/;

console.log(reg.exec("b1"));       //["b1"]
console.log(reg.exec("b2aa"));      //["b2"]
console.log(reg.exec("bza"));      //null
console.log(reg.exec("b"));        //null

w:匹配字母、數(shù)字和下劃線(單詞記憶法 => 單詞【word】)

const reg = /bw/;

console.log(reg.exec("b1"));     //["b1"]
console.log(reg.exec("b2aa"));     //["b2"]
console.log(reg.exec("bza"));      //["bz"]
console.log(reg.exec("b"));       //null

:匹配一個邊界,一個獨立單詞的開頭或結(jié)尾(單詞記憶法 => 邊界【border】)

const str = "moon is white";

console.log(str.match(/m/));     //["m"]
console.log(str.match(/oon/));     //["oon"]

s:匹配空白符(空格、換行符、制表符)(單詞記憶法 => 符號【space】)

const str = "moon is white";

console.log(str.match(/isswhite/));    //["is white"]
console.log(str.match(/moonsis/));    // ["moon is"]

反元字符([^x]、D、W、B、S)

[^x]:匹配除x之外的任意字符

const reg = /b[^a]/;

console.log(reg.exec("ba"));     //null
console.log(reg.exec("bz"));     //["bz"]
console.log(reg.exec("by"));    //["by"]

D:匹配除數(shù)字之外的任意字符,與d相反

const reg = /bD/;

console.log(reg.exec("b1"));    //null
console.log(reg.exec("b2"));    //null
console.log(reg.exec("by"));     //["by"]

W:匹配除數(shù)字、字母和下劃線以外的任意字符,與w相反

const reg = /bW/;

console.log(reg.exec("b1"));     //null
console.log(reg.exec("ba"));     //null
console.log(reg.exec("b_"));      //null
console.log(reg.exec("b*"));      //["b*"]

B:匹配非單詞邊界的字符,與b相反

const str = "moon is white";

console.log(str.match(/Boon/));     //["oon"]
console.log(str.match(/whitB/));      //["whit"]

S:匹配非空白字符,與s相反

const str = "moon is white";

console.log(str.match(/moSn/));    //["moon"]
console.log(str.match(/whitS/));      //["white"]

字符組([...])

[...]:匹配方括號中的字符集合,例如[0-9] => 匹配數(shù)字字符

const reg = /b[a-z]/;

console.log(reg.test("ba"));      //true
console.log(reg.test("bA"));       //false

分組((...))

(X):將括號中的字符看成一個組進行匹配,例如(ab)+ => 可以匹配"ababab"

const reg = /(abab)+/;

console.log(reg.exec("ababab"));     //["abab", "abab"]
console.log(reg.exec("abababab"));   //["abababab","abab"]

(?:X):匹配X,但是不記錄匹配項。而上面的(X)是記錄匹配項的。
(?=X):正向肯定查找,即匹配后面緊跟X的字符串。

const reg = /d+(?=.)/;

console.log(reg.exec("3.141"))  //["3"]

(?!X):正向否定查找,即匹配后面不跟X的字符串,與(?:X)相反。

const reg = /d+(?!.)/;

console.log(reg.exec("3.141"))   //["141"]

多選符 (|)

|:匹配兩者中的一個,例如a|b => 匹配a或b

const reg = /a|b/;

console.log(reg.exec("a"));     //["a"]
console.log(reg.exec("b"));     //["b"]
console.log(reg.exec("c"));      //["c"]

轉(zhuǎn)移字符()

:表示轉(zhuǎn)義字符,將特殊的字符轉(zhuǎn)義成普通字符進行匹配

匹配方式

匹配方式,即正則表達式在匹配過程中,當(dāng)具備多個結(jié)果時,按照一定的模式進行匹配。

匹配方式可分為兩種,貪婪模式和非貪婪模式。

貪婪模式:即以限定符最大重復(fù)標(biāo)準進行匹配。例如:使用/ba*/匹配"baaaaa"時,結(jié)果可返回"baaaaa"

非貪婪模式:即以限定符最小重復(fù)標(biāo)準進行匹配。例如:使用/ba*?/匹配"baaaaa"時,結(jié)果可返回"b"

const str = "baaaaa";

console.log(str.match(/ba*/));           //["baaaaa"]
console.log(str.match(/ba*?/));        //["b"]

其中?符號起到了貪婪與非貪婪模式之間的轉(zhuǎn)變,在重復(fù)限定符后加上?,按非貪婪模式進行匹配;默認為貪婪模式。

標(biāo)識方式

標(biāo)識方式,就是正則表達式后面跟的匹配方式,flag

g:全局匹配,記憶方式【global】

i:忽略大小寫,記憶方式【ignore】

m:多行搜索,記憶方式【multline】

方法

使用正則表達式的方式一共有6種,可以分成:reg有兩種,string有四種。

首先,我們來看一下reg對象帶的兩種方法:exec和test

test => 判斷字符串中是否存在與正則表達式匹配的字符串,返回boolean類型

測試用例:

const reg = /abc/;

console.log(reg.test("abca"));     //true
console.log(reg.test("abac"));     //false

exec => 匹配字符串中滿足條件的字符串,返回一個匹配的結(jié)果數(shù)組

const reg = /d+/;

console.log(reg.exec("1234dhi343sf2"));    //["1234"]

之后是string的四種方法:match、search、replace、split

match:查找字符串中的匹配的字符串,返回一個結(jié)果數(shù)組,若沒有匹配則返回null

const str = "this is reg expression test"

console.log(str.match(/i.sw+/)); //["is reg"]

search:查找字符串中匹配的字符串,返回匹配字符串的下標(biāo),若沒有匹配則返回-1

const str = "this is reg expression test"

console.log(str.search(/i.sw+/));    //5

replace:查找字符串中匹配的字符串,對其進行替換(這是一個個人覺得比較厲害的技能)

接收字符串

var str = "this is reg expression test"

console.log(str.replace(/(i.)s(w+)/, "$1 hello $2"));    //"this is hello reg expression test"

接收函數(shù)

var str = "this is reg expression test"

str.replace(/(i.)s(w+)/, (...args) => {
   console.log(args);
});    //["is reg", "is", "reg", 5, "this is reg expression test"]

注:這個函數(shù)會有一些參數(shù),第一個是匹配的字符串,第二個是第一項匹配的,第三個是第二項匹配的,第四個是匹配的下標(biāo),第五個是原字符串

split:使用正則表達式或者固定字符,分割字符串

var str = "this is reg expression test"

console.log(str.split(/s/))   //["this", "is", "reg", "expression", "test"]
總結(jié)

js部分的正則表達式很多東西都以及講完了,剩下的就是練習(xí)了。這種記憶性的東西,需要不斷的使用,才會孰能生巧。下面部分提供一下練習(xí)的語句,答案在js正則表達式練習(xí)整理

如果你對我寫的有疑問,可以評論,如我寫的有錯誤,歡迎指正。你喜歡我的博客,請給我關(guān)注Star~呦。大家一起總結(jié)一起進步。歡迎關(guān)注我的github博客

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

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

相關(guān)文章

  • JS基礎(chǔ)篇--正則達式詳解

    摘要:下面整理一些常用的正則表達式。正則表達式中可以使用編碼。每個正則表達式可帶有一個或者多個標(biāo)注用以標(biāo)明正則表達式的行為。其中表示匹配項在字符串中的位置,而表示應(yīng)用字符串表達式的字符串。 正則表達式非常有用,查找、匹配、處理字符串、替換和轉(zhuǎn)換字符串,輸入輸出等。下面整理一些常用的正則表達式。 常用的正則字符 正則字符 描述 :將下一個字符標(biāo)記為一個特殊字符、或一個原義字符、或一個 向...

    shmily 評論0 收藏0
  • JS正則達式詳解

    摘要:正則表達式中可以使用編碼。每個正則表達式可帶有一個或者多個標(biāo)注用以標(biāo)明正則表達式的行為。其中表示匹配項在字符串中的位置,而表示應(yīng)用字符串表達式的字符串。方法正則表達式常用方法,它接受一個字符串參數(shù)。 正則表達式非常有用,查找、匹配、處理字符串、替換和轉(zhuǎn)換字符串,輸入輸出等。下面整理一些常用的正則表達式。 常用的正則字符 正則字符 描述 將下一個字符標(biāo)記為一個特殊字符、...

    xiguadada 評論0 收藏0
  • js--string/正則達式replace方法詳解

    摘要:方法是涉及到正則表達式中較為復(fù)雜的一個方法,嚴格上說應(yīng)該是對象的方法。字符串中要替換的子串或正則第二個參數(shù)必需,一個字符串值,規(guī)定了替換文本或生成替換文本的函數(shù)。如果具有全局標(biāo)志,那么方法將替換所有匹配的子串。 replace方法是javascript涉及到正則表達式中較為復(fù)雜的一個方法,嚴格上說應(yīng)該是string對象的方法。只不過牽扯到正則的時候比較多一些。需要我們靈活的使用。 語法...

    lifefriend_007 評論0 收藏0
  • 前端文檔收集

    摘要:系列種優(yōu)化頁面加載速度的方法隨筆分類中個最重要的技術(shù)點常用整理網(wǎng)頁性能管理詳解離線緩存簡介系列編寫高性能有趣的原生數(shù)組函數(shù)數(shù)據(jù)訪問性能優(yōu)化方案實現(xiàn)的大排序算法一怪對象常用方法函數(shù)收集數(shù)組的操作面向?qū)ο蠛驮屠^承中關(guān)鍵詞的優(yōu)雅解釋淺談系列 H5系列 10種優(yōu)化頁面加載速度的方法 隨筆分類 - HTML5 HTML5中40個最重要的技術(shù)點 常用meta整理 網(wǎng)頁性能管理詳解 HTML5 ...

    jsbintask 評論0 收藏0

發(fā)表評論

0條評論

fredshare

|高級講師

TA的文章

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