摘要:程序員的正則表達式,醫(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
摘要:下面整理一些常用的正則表達式。正則表達式中可以使用編碼。每個正則表達式可帶有一個或者多個標(biāo)注用以標(biāo)明正則表達式的行為。其中表示匹配項在字符串中的位置,而表示應(yīng)用字符串表達式的字符串。 正則表達式非常有用,查找、匹配、處理字符串、替換和轉(zhuǎn)換字符串,輸入輸出等。下面整理一些常用的正則表達式。 常用的正則字符 正則字符 描述 :將下一個字符標(biāo)記為一個特殊字符、或一個原義字符、或一個 向...
摘要:正則表達式中可以使用編碼。每個正則表達式可帶有一個或者多個標(biāo)注用以標(biāo)明正則表達式的行為。其中表示匹配項在字符串中的位置,而表示應(yīng)用字符串表達式的字符串。方法正則表達式常用方法,它接受一個字符串參數(shù)。 正則表達式非常有用,查找、匹配、處理字符串、替換和轉(zhuǎn)換字符串,輸入輸出等。下面整理一些常用的正則表達式。 常用的正則字符 正則字符 描述 將下一個字符標(biāo)記為一個特殊字符、...
摘要:方法是涉及到正則表達式中較為復(fù)雜的一個方法,嚴格上說應(yīng)該是對象的方法。字符串中要替換的子串或正則第二個參數(shù)必需,一個字符串值,規(guī)定了替換文本或生成替換文本的函數(shù)。如果具有全局標(biāo)志,那么方法將替換所有匹配的子串。 replace方法是javascript涉及到正則表達式中較為復(fù)雜的一個方法,嚴格上說應(yīng)該是string對象的方法。只不過牽扯到正則的時候比較多一些。需要我們靈活的使用。 語法...
摘要:系列種優(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 ...
閱讀 1868·2023-04-25 23:28
閱讀 579·2023-04-25 22:49
閱讀 2259·2021-09-27 13:34
閱讀 5229·2021-09-22 15:09
閱讀 3623·2019-08-30 12:52
閱讀 2752·2019-08-29 15:26
閱讀 666·2019-08-29 11:12
閱讀 2201·2019-08-26 12:24