摘要:則是將作為一組,表示出現(xiàn)多次。如果沒有使用標(biāo)示,則僅返回第一個完整匹配及其相關(guān)的捕獲組。構(gòu)造函數(shù)的全局屬性到存儲了分組匹配的結(jié)果。
感謝
本文參考《正則表達式迷你書》
分組和分支結(jié)構(gòu) 分組括號可以提供分組的功能。/a+/, 標(biāo)示a出現(xiàn)多次。/(ab)+/, 則是將ab作為一組,表示ab出現(xiàn)多次。
分組引用使用括號可以實現(xiàn)數(shù)據(jù)提取和替換操作。我們以匹配日期(yyyy-mm-dd)為例
// 無括號版本 var reg1 = /d{4}-d{2}-d{2}/
// 有括號版本 var reg2 = /(d{4})-(d{2})-(d{2})/
正則引擎在匹配的過程中,會存儲每一個分組匹配到的數(shù)據(jù)
提取分組數(shù)據(jù) match方法match接受一個正則表達式作為參數(shù)。如果正則表達式中有g(shù)標(biāo)示, 將返回與完整正則表達式匹配的所有結(jié)果,但不會返回捕獲組。如果沒有使用g標(biāo)示,則僅返回第一個完整匹配及其相關(guān)的捕獲組。
var regex = /(d{4})-(d{2})-(d{2})/g var string = "2017-06-12 2017-06-12" // ["2017-06-12", "2017-06-12"] // 返回與完整正則表達式匹配的所有結(jié)果, 不含分組的結(jié)果 string.match(regex)
var regex = /(d{4})-(d{2})-(d{2})/ var string = "2017-06-12 2017-06-12" // 只返回第一個完整匹配和其分組 // ["2017-06-12", "2017", "06", "12", index: 0, input: "2017-06-12 2017-06-12", groups: undefined] string.match(regex)exec方法
exec方法接受一個字符串作為參數(shù)。如果exec匹配失敗將會返回null, 如果匹配成功exec方法將會返回一個數(shù)組。
返回的數(shù)組將完全匹配成功的文本作為第一項,而分組匹配的結(jié)果在數(shù)組位置0的后面。返回的結(jié)果同時擁有index屬性, 標(biāo)示了匹配字符為于原始字符的索引。input屬性則是原始的字符串。
注意當(dāng)正則對象是否包含g返回結(jié)果是不一樣的。如果正則中含有g(shù)標(biāo)示, 那么正則對象的lastIndex(下一次匹配開始的位置), 會更新。而如果不含有g(shù), 正則的lastIndex不會更新。
var regex = /(d{4})-(d{2})-(d{2})/ var string = "2017-06-12 2017-06-12" // ["2017-06-12", "2017", "06", "12", index: 0, input: "2017-06-12 2017-06-12", groups: undefined] // regex.lastIndex === 0 regex.exec(string) // ["2017-06-12", "2017", "06", "12", index: 0, input: "2017-06-12 2017-06-12", groups: undefined] // regex.lastIndex === 0 regex.exec(string)
var regex = /(d{4})-(d{2})-(d{2})/g var string = "2017-06-12 2017-06-12" // ["2017-06-12", "2017", "06", "12", index: 0, input: "2017-06-12 2017-06-12", groups: undefined] regex.exec(string) // ["2017-06-12", "2017", "06", "12", index: 11, input: "2017-06-12 2017-06-12", groups: undefined] // regex.lastIndex === 21 regex.exec(string)RegEx
我們也可以通過RegEx全局的構(gòu)造函數(shù)來獲取分組匹配的結(jié)果。構(gòu)造函數(shù)的全局屬性$1到$9存儲了分組匹配的結(jié)果。
var regex = /(d{4})-(d{2})-(d{2})/g var string = "2017-06-12 2017-06-12" // 任何正則操作即可 regex.exec(string) // "2017" RegExp.$1替換分組數(shù)據(jù)
我們可以通過replace方法配合分組匹配的結(jié)果, 實現(xiàn)替換分組數(shù)據(jù)
replacestr.replace(regexp|substr, newSubStr|func)
regexp 一個正則表達式對象,該正則所匹配的內(nèi)容會被replace的第二個參數(shù)(或者函數(shù)的返回值)替換掉
substr 當(dāng)str中含有substr, 會被第二個參數(shù)替換, 僅有第一個匹配項會被替換
newSubStr 用于替換掉第一個參數(shù)在原字符串中的匹配部分的字符串。該字符串中可以內(nèi)插一些特殊的變量名(見下表)
func 函數(shù)的返回值將替換掉第一個參數(shù)匹配到的結(jié)果
變量名 | 含義 |
---|---|
$1, $2, $3…… | 第n個分組匹配的結(jié)果 |
$` | 插入當(dāng)前匹配的子串左邊的內(nèi)容 |
$" | 插入當(dāng)前匹配的子串右邊的內(nèi)容 |
$& | 當(dāng)前匹配的子串 |
// "
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/103163.html
摘要:為了方便廣大的開發(fā)者,特此統(tǒng)計了網(wǎng)上諸多的免費,為您收集免費的接口服務(wù),做一個的搬運工,以后會每月定時更新新的接口。將長段中文切詞分開。 為了方便廣大的開發(fā)者,特此統(tǒng)計了網(wǎng)上諸多的免費API,為您收集免費的接口服務(wù),做一個api的搬運工,以后會每月定時更新新的接口。有些接口來自第三方,在第三方注冊就可以成為他們的會員,免費使用他們的部分接口。 百度AccessToken:針對HTTP ...
摘要:原型模式平行的繼承層次使用工廠模式在大型設(shè)計中,必須去維護大量的產(chǎn)品類。上文中,稱之為特殊的耦合在這里我們介紹一種其抽象工廠模式的變體原型模式。面向?qū)ο笤O(shè)計模式目錄 原型模式 平行的繼承層次使用工廠模式在:大型設(shè)計中,必須去維護大量的產(chǎn)品類。(上文中,稱之為特殊的耦合) 在這里我們介紹一種其抽象工廠模式的變體:原型模式。它使用clone關(guān)鍵詞,來復(fù)制具體產(chǎn)品類,使得具體產(chǎn)品類能完成自我...
摘要:先看一張來自于菜鳥教程的定義四種形式,加和不加有什么區(qū)別,區(qū)別就是捕獲元與非捕獲元,表現(xiàn)形式就是用方法去匹配,捕獲組會單純保存在一組變量中。捕獲元與非捕獲元搞懂了,那與啥區(qū)別呢,答案,兩個區(qū)別。 想讀懂世間所有的那些變態(tài)正則表達式?做夢,年紀(jì)輕輕,想啥呢,盡自己最大努力學(xué)就行 引子 JS學(xué)了用了也快一兩年了,對象啥的找到了也會用了,繼承啥的也入門了,但看別人的框架代碼,總是會隨時卡殼,...
摘要:和后起之秀是文檔類中的佼佼者。因為部分作者提出延期申請,且恰逢春節(jié)假期,本次舉辦方考慮到各方因素,特此將截稿日期延期至月號。 大數(shù)據(jù)包含大利潤,對于一些數(shù)據(jù)量龐大的企業(yè),高擴展的非關(guān)系型數(shù)據(jù)庫的使用往往已經(jīng)超過關(guān)系型數(shù)據(jù)庫,而這種新型數(shù)據(jù)庫我們稱之為NoSQL。MongoDB和后起之秀SequoiaDB是文檔類NoSQL中的佼佼者。 鑒于這兩種數(shù)據(jù)庫(MongoDB和SequoiaD...
閱讀 1753·2021-10-13 09:39
閱讀 1323·2019-08-30 13:58
閱讀 1415·2019-08-29 16:42
閱讀 3565·2019-08-29 15:41
閱讀 2997·2019-08-29 15:11
閱讀 2484·2019-08-29 14:10
閱讀 3413·2019-08-29 13:29
閱讀 2096·2019-08-26 13:27