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

資訊專(zhuān)欄INFORMATION COLUMN

JS正則表達(dá)式精簡(jiǎn)教程(JavaScript RegExp 對(duì)象)

ACb0y / 1368人閱讀

摘要:返回值是被找到的值。支持正則表達(dá)式的對(duì)象的方法方法檢索與正則表達(dá)式相匹配的子字符串。該數(shù)組是通過(guò)在指定的邊界處將字符串分割成子串創(chuàng)建的。注意報(bào)錯(cuò)正確示例附表修飾符修飾符描述執(zhí)行對(duì)大小寫(xiě)不敏感的匹配。查找以十六進(jìn)制數(shù)規(guī)定的字符。

什么是 RegExp?

RegExp 是正則表達(dá)式的縮寫(xiě)。

當(dāng)您檢索某個(gè)文本時(shí),可以使用一種模式來(lái)描述要檢索的內(nèi)容。RegExp 就是這種模式。

簡(jiǎn)單的模式可以是一個(gè)多帶帶的字符。

更復(fù)雜的模式包括了更多的字符,并可用于解析、格式檢查、替換等等。

您可以規(guī)定字符串中的檢索位置,以及要檢索的字符類(lèi)型,等等。

定義 RegExp
const pattern = new RegExp("str");
RegExp 對(duì)象的方法

test()

exec()

compile()

test() 方法檢索字符串中的指定值。返回值是 true 或 false。

const pattern = new RegExp("str");
console.log(pattern.test("input string")); // true

exec() 方法檢索字符串中的指定值。返回值是被找到的值。如果沒(méi)有發(fā)現(xiàn)匹配,則返回 null。

const pattern = new RegExp("str");
console.log(pattern.test("input string")); // [ "str", index: 6, input: "input string", groups: undefined ]

compile() 方法用于改變 RegExp(既可以改變檢索模式,也可以添加或刪除第二個(gè)參數(shù))。

const pattern = new RegExp("e");
console.log(pattern.test("The best things in life are free"));
pattern.compile("d");
console.log(pattern.test("The best things in life are free"));
支持正則表達(dá)式的 String 對(duì)象的方法

search()

match()

replace()

split()

search()方法檢索與正則表達(dá)式相匹配的子字符串。search() 方法不執(zhí)行全局匹配,它將忽略標(biāo)志 g。它同時(shí)忽略 regexp 的 lastIndex 屬性,并且總是從字符串的開(kāi)始進(jìn)行檢索,這意味著它總是返回 stringObject 的第一個(gè)匹配的位置。

// stringObject.search(regexp) 語(yǔ)法 (匹配不上時(shí)返回 -1)

const stringObj = "Hello world";
const result = stringObj.search(/l{3}/);
console.log(result); // -1

match() 方法可在字符串內(nèi)檢索指定的值,或找到一個(gè)或多個(gè)正則表達(dá)式的匹配。該方法類(lèi)似 indexOf() 和 lastIndexOf(),但是它返回指定的值,而不是字符串的位置。

// stringObject.match(regexp) 語(yǔ)法 (匹配不上時(shí)返回 null)

const stringObj = "Hello world";
const result = stringObj.match(/l{2}/);
console.log(result); // [ "ll", index: 2, input: "Hello world", groups: undefined ]

replace() 方法用于在字符串中用一些字符替換另一些字符,或替換一個(gè)與正則表達(dá)式匹配的子串。
字符串 stringObject 的 replace() 方法執(zhí)行的是查找并替換的操作。它將在 stringObject 中查找與 regexp 相匹配的子字符串,然后用 replacement 來(lái)替換這些子串。如果 regexp 具有全局標(biāo)志 g,那么 replace() 方法將替換所有匹配的子串。否則,它只替換第一個(gè)匹配子串。

// stringObject.replace(regexp/substr,replacement) 語(yǔ)法 (匹配不上時(shí)返回原字符串)

const stringObj = "Hello world";
const result = stringObj.replace(/l{2}/,"ii");
console.log(result); // Heiio world

split() 方法用于把一個(gè)字符串分割成字符串?dāng)?shù)組。
返回一個(gè)字符串?dāng)?shù)組。該數(shù)組是通過(guò)在 separator 指定的邊界處將字符串 stringObject 分割成子串創(chuàng)建的。返回的數(shù)組中的字串不包括 separator 自身。
但是,如果 separator 是包含子表達(dá)式的正則表達(dá)式,那么返回的數(shù)組中包括與這些子表達(dá)式匹配的字串(但不包括與整個(gè)正則表達(dá)式匹配的文本)。

// stringObject.split(separator,howmany) 語(yǔ)法 (匹配不上時(shí)返回 [stringObject])

const stringObj = "Hello world";
const result = stringObj.split(/l{2}/);
console.log(result) // [ "He", "o world" ]
RegExp 參數(shù)

直接量語(yǔ)法

/pattern/attributes

創(chuàng)建 RegExp 對(duì)象的語(yǔ)法

new RegExp(pattern, attributes);

參數(shù) pattern 是一個(gè)字符串,指定了正則表達(dá)式的模式或其他正則表達(dá)式。

參數(shù) attributes 是一個(gè)可選的字符串,包含屬性 "g"、"i" 和 "m",分別用于指定全局匹配、區(qū)分大小寫(xiě)的匹配和多行匹配。ECMAScript 標(biāo)準(zhǔn)化之前,不支持 m 屬性。如果 pattern 是正則表達(dá)式,而不是字符串,則必須省略該參數(shù)。

注意

const reg = /str/;
const newReg = reg.compile(reg, "i"); // 報(bào)錯(cuò)
console.log(newReg.test("string"))

// 正確示例
const reg = /str/;
const newReg = new RegExp(reg, "i");
console.log(newReg.test("string"));
附表

修飾符

修飾符 描述
i 執(zhí)行對(duì)大小寫(xiě)不敏感的匹配。
g 執(zhí)行全局匹配
m 執(zhí)行多行匹配

方括號(hào)

表達(dá)式 描述
[abc] 查找方括號(hào)之間的任何字符
1 查找任何不在方括號(hào)之間的任何字符
[0-9] 查找任何從0至9的數(shù)字
[a-z] 查找任何從小寫(xiě)a至小寫(xiě)z的字符
[A-Z] 查找任何從大寫(xiě)A至大寫(xiě)Z的字符
[A-z] 查找任何從大寫(xiě)A至小寫(xiě)z的字符
[adgk] 查找給定集合內(nèi)的任何字符
[^adgk] 查找給定集合外的任何字符
(red | blue |green) 查找任何指定的選項(xiàng)

元字符

元字符 描述
. 查找單個(gè)字符,除了換行和行結(jié)束符。
w 查找單詞字符。
W 查找非單詞字符。
d 查找數(shù)字字符。
D 查找非數(shù)字字符。
s 查找空白字符。
S 查找非空白字符。
b 匹配單詞邊界。
B 匹配非單詞邊界。
0 查找 NUL 字符。
n 查找換行符。
f 查找換頁(yè)符。
r 查找回車(chē)符。
t 查找制表符。
v 查找垂直制表符。
xxx 查找以八進(jìn)制數(shù) xxx 規(guī)定的字符。
xdd 查找以十六進(jìn)制數(shù) dd 規(guī)定的字符。
uxxxx 查找以十六進(jìn)制數(shù) xxxx 規(guī)定的 Unicode 字符。

量詞

元字符 描述
n+ 匹配任何包含至少一個(gè) n 的字符串。
n* 匹配任何包含零個(gè)或多個(gè) n 的字符串。
n? 匹配任何包含零個(gè)或一個(gè) n 的字符串。
n{X} 匹配包含 X 個(gè) n 的序列的字符串。
n{X,Y} 匹配包含 X 至 Y 個(gè) n 的序列的字符串。
n{X,} 匹配包含至少 X 個(gè) n 的序列的字符串。
n$ 匹配任何結(jié)尾為 n 的字符串。
^n 匹配任何開(kāi)頭為 n 的字符串。
?=n 匹配任何其后緊接指定字符串 n 的字符串。
?!n 匹配任何其后沒(méi)有緊接指定字符串 n 的字符串。
  • abc ?

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

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

    相關(guān)文章

    • 前端資源系列(4)-前端學(xué)習(xí)資源分享&前端面試資源匯總

      摘要:特意對(duì)前端學(xué)習(xí)資源做一個(gè)匯總,方便自己學(xué)習(xí)查閱參考,和好友們共同進(jìn)步。 特意對(duì)前端學(xué)習(xí)資源做一個(gè)匯總,方便自己學(xué)習(xí)查閱參考,和好友們共同進(jìn)步。 本以為自己收藏的站點(diǎn)多,可以很快搞定,沒(méi)想到一入?yún)R總深似海。還有很多不足&遺漏的地方,歡迎補(bǔ)充。有錯(cuò)誤的地方,還請(qǐng)斧正... 托管: welcome to git,歡迎交流,感謝star 有好友反應(yīng)和斧正,會(huì)及時(shí)更新,平時(shí)業(yè)務(wù)工作時(shí)也會(huì)不定期更...

      princekin 評(píng)論0 收藏0
    • js溫故而知新5——學(xué)習(xí)廖雪峰的js教程

      摘要:表示行的結(jié)束,表示必須以數(shù)字結(jié)束。用表示的就是要提取的分組。方法在匹配成功后,會(huì)返回一個(gè),第一個(gè)元素是正則表達(dá)式匹配到的整個(gè)字符串,后面的字符串表示匹配成功的子串。貪婪匹配需要特別指出的是,正則匹配默認(rèn)是貪婪匹配,也就是匹配盡可能多的字符。 對(duì)象 typeof 123; // number typeof NaN; // number typeof str; // string type...

      mayaohua 評(píng)論0 收藏0
    • JavaScript標(biāo)準(zhǔn)庫(kù)系列——RegExp對(duì)象(三)

      摘要:目錄導(dǎo)語(yǔ)理解正則表達(dá)式模式的規(guī)則字符串和正則實(shí)例的屬性和方法檢索實(shí)例小結(jié)導(dǎo)語(yǔ)正則表達(dá)式是處理字符串的一門(mén)藝術(shù)手法,應(yīng)用場(chǎng)景經(jīng)常出現(xiàn)在表單驗(yàn)證部分高級(jí)程序設(shè)計(jì)一書(shū)開(kāi)篇提到,這門(mén)語(yǔ)言最原始的應(yīng)用就是處理輸入驗(yàn)證操作,所以正則表達(dá)式從誕生那一刻就 目錄 導(dǎo)語(yǔ) 1.理解正則表達(dá)式 2.模式的規(guī)則 3.字符串和正則實(shí)例的屬性和方法 4.檢索實(shí)例 5. 小結(jié) 導(dǎo)語(yǔ) 正則表達(dá)式是處理字符串的一門(mén)藝...

      邱勇 評(píng)論0 收藏0
    • 正則達(dá)式

      摘要:本文內(nèi)容共正則表達(dá)式火拼系列正則表達(dá)式回溯法原理學(xué)習(xí)正則表達(dá)式,是需要懂點(diǎn)兒匹配原理的。正則表達(dá)式迷你書(shū)問(wèn)世了讓幫你生成和解析參數(shù)字符串最全正則表達(dá)式總結(jié)驗(yàn)證號(hào)手機(jī)號(hào)中文郵編身份證地址等是正則表達(dá)式的縮寫(xiě),作用是對(duì)字符串執(zhí)行模式匹配。 JS 的正則表達(dá)式 正則表達(dá)式 一種幾乎可以在所有的程序設(shè)計(jì)語(yǔ)言里和所有的計(jì)算機(jī)平臺(tái)上使用的文字處理工具。它可以用來(lái)查找特定的信息(搜索),也可以用來(lái)查...

      bang590 評(píng)論0 收藏0
    • 溫故js系列(5)-正則達(dá)式&常用代碼

      摘要:的對(duì)象表示正則表達(dá)式,而和都定義了使用正則表達(dá)式進(jìn)行強(qiáng)大的模式匹配和文本檢索與替換的函數(shù)。對(duì)象也提供了個(gè)使用正則表達(dá)式的方法。如正則表達(dá)式將匹配除了和所有大寫(xiě)字母之外的任何字符。 前端學(xué)習(xí):教程&開(kāi)發(fā)模塊化/規(guī)范化/工程化/優(yōu)化&工具/調(diào)試&值得關(guān)注的博客/Git&面試-前端資源匯總 歡迎提issues斧正:正則表達(dá)式 JavaScript-正則表達(dá)式 正則表達(dá)式簡(jiǎn)述 正則表達(dá)式(re...

      glumes 評(píng)論0 收藏0

    發(fā)表評(píng)論

    0條評(píng)論

    最新活動(dòng)
    閱讀需要支付1元查看
    <