摘要:日常代碼的開發(fā)中,大家都或多或少的碰到一些正則表達(dá)式,但有的朋友只是會用,或者大致明白,希望這篇對正則深入淺出的文章能夠讓大家有所收獲。主要可以干的事情有兩個,引用和反向引用,在一些稍微復(fù)雜的正則表達(dá)式里,我們常常會用到這些。
日常代碼的開發(fā)中,大家都或多或少的碰到一些正則表達(dá)式,但有的朋友只是會用,或者大致明白,希望這篇對正則深入淺出的文章能夠讓大家有所收獲。基本語法
[xyz] 一個字符集,匹配任意一個包含的字符 [^xyz] 一個否定字符集,匹配任何為包含的字符 w (小寫) 匹配字母或數(shù)字或者下劃線的字符 W (大寫) 匹配不是字母,數(shù)字,下劃線的字符 s (小寫) 匹配任意空白符 S (大寫) 匹配不是空白符的字符 d (小寫) 匹配數(shù)字 D (大寫) 匹配非數(shù)字的字符 (小寫) 匹配單詞的開始或結(jié)束的位置 B (大寫) 匹配不是單詞開頭或結(jié)束的位置 $ 匹配字符串的結(jié)束 ^ 匹配字符串的開始 . 匹配所有,除了換行符 - 重復(fù)0次或更多次 - 重復(fù)1次或更多次 ? 重復(fù)0次或一次 {n} 重復(fù)n次 {n,} 重復(fù)n次或更多次 {n, m} 重復(fù)n次到m次 等更多.........
更多語法可以在W3C正則里查看
匹配位置需要強(qiáng)調(diào)一下匹配位置的幾個語法, 后面會一一舉例說明
^ 匹配字符串的開始
$ 匹配字符串的結(jié)尾
(?=pattern) 正向前瞻,字符串匹配滿足條件的位置
(?!pattern) 負(fù)向前瞻,字符串匹配滿足條件的位置
正則表達(dá)式的寫法有兩種
var reg = new RegExp("/1/") var reg = /1/
reg是正則對象的實例,通過console.dir打印對象,我們能看到實例上面的屬性和方法。
常用的方法
舉個簡單的例子,我們來了解下test()和exec()的區(qū)別和使用場景。
var reg = /1/, reg1 = /(1)/ reg.test(1111) // true reg.test(222) // false reg.exec(11112) // ["1", index: 0, input: "11112"] reg1.exec(11112) // ["1111", "1", index: 0, input: "11112"] reg1.exec(222) // null
test驗證后會返回一個布爾值,主要用于驗證是否匹配,exec則在驗證成功后返回一個類似數(shù)組的對象,主要用于捕獲分組,失敗則返回null。
reg1是一個匹配(1)分組的正則,使用exec匹配成功后返回["1111", "1", index: 0, input: "11112"],input是輸入的值,第一項是匹配滿足條件的數(shù)據(jù),第二項是匹配到的分組,如果沒有分組,第二項則不存在,index屬性則表示從第幾項開始匹配到。
關(guān)于分組的話在下面會有詳細(xì)的例子說明。
常用的屬性
ignoreCase 忽略大小寫,默認(rèn)為false global 全局匹配,默認(rèn)為false multiline 在有換行的時候,可以得到換行的起始位置和終止位置,默認(rèn)為false匹配規(guī)則
正則表達(dá)式(regular expression)描述了一種字符串匹配的模式,可以用來檢查一個串是否含有某種子串、將匹配的子串做替換或者從某個串中取出符合某個條件的子串等
當(dāng)當(dāng)看描述和說明文檔可能有點太官方化了,先假設(shè)我們已經(jīng)都了解了正則匹配的基本語法和大致的使用,接下來這里用簡淺的例子一步一步來分析怎樣去實現(xiàn)自己需要的正則表達(dá)式。
例子: 手機(jī)號碼
首先舉個例子,要匹配一個手機(jī)號碼。先分析一下手機(jī)號碼有什么樣的規(guī)則呢,1開頭,必須為數(shù)字,而且總共長度為十一位,那我們就有了下面這個表達(dá)式:
var reg = /^1[0-9]{10}$/ // 根據(jù)正則語法 ^為匹配開始,^1就表示第一位必須為1開頭,[0-9]指的是必須為0-9的數(shù)字,{10}表示重復(fù)次數(shù)為10,$結(jié)束符。簡單的匹配規(guī)則完成。
好像有點粗糙,一般手機(jī)號碼第二位是不會有0-9這么多的可能的,所以我們需要在優(yōu)化一下,第一位為1,第二位為[3,5,8,7]:
var reg = /^1[3,5,8,7]{1}[0-9]{9}$/ // 根據(jù)正則語法 ^為匹配開始,^1就表示第一位必須為1開頭,[3,5,8,7]指的是匹配其中任一數(shù)字,{1}表示重復(fù)次數(shù)為1,前兩位匹配完成,加上后面的[0-9],{9}重復(fù)九次,$結(jié)束符。簡單的匹配規(guī)則完成。
這樣,基本的一個手機(jī)號碼的正則匹配規(guī)則就出來了,如果自己業(yè)務(wù)有需求,做相對應(yīng)的改動就可以了。
例子:郵箱
和手機(jī)號碼的規(guī)則相比較,郵箱的匹配規(guī)則稍微復(fù)雜一點。同樣,我們先分析郵箱的規(guī)則,比如QQ郵箱,110@qq.com,先有字符,長度大于1,然后是@,后面再跟著一串字符長度大于1,那我們就可以得到這樣一個的表達(dá)式:
var reg = /^[w.]+@[w.]+$/ // [w.] w匹配字母或數(shù)字或者下劃線的字符,.通過轉(zhuǎn)義符表示匹配.,+表示重復(fù)一次或更多次,匹配@符號,然后又是同樣的w.匹配一次或更多次。
例子:網(wǎng)站
同樣是分析網(wǎng)站規(guī)則,http(s)://segmentfault.com/1233, 首先可能是http協(xié)議或者h(yuǎn)ttps協(xié)議,然后是://,然后是字符串。這樣一分析,再把對應(yīng)的正則語法理一理,很快一個匹配規(guī)則就出來了:
var reg = /^https?://.+$/ // 首先會是http開頭,^http, 然后s跟隨?表示匹配0次或一次,:,//需要用轉(zhuǎn)義,后面跟隨各種類型的不確定因素.+,當(dāng)然,如果我們要做的更精確的匹配,則可以修改成自己的規(guī)則即可。
舉了幾個基本的例子,讓我們?nèi)?fù)習(xí)鞏固正則的基本使用和匹配規(guī)則,首先分析要匹配的規(guī)則是什么,然后一步一步去把規(guī)則拼積木一樣拼進(jìn)去,就可以了,自己多定義一些不一樣的規(guī)則然后去一個一個實現(xiàn),就會發(fā)現(xiàn)如果只是基本的使用,遠(yuǎn)沒有想象中的難。
分組分組的就是把要匹配的規(guī)則分成一個組,寫在()里,比如匹配數(shù)字(0-9),匹配字母(0-z),主要有分為捕獲型分組和非捕獲型分組。
捕獲型分組
先來說說捕獲型分組。主要可以干的事情有兩個,引用和反向引用,在一些稍微復(fù)雜的正則表達(dá)式里,我們常常會用到這些。
捕獲型分組-引用
在每次分組捕獲之后,RegExp對象上面可以拿到最近捕獲到的分組,下面來舉一些例子:
var reg = /(1)(3)/ // 兩個分組 reg.exec(123134) // 捕獲到了兩個分組 console.log(RegExp.$1) // 1 console.log(RegExp.$2) // 3
得到到了最近捕獲的分組,可是往往我們不明白捕獲到了分組有什么用,下面舉個例子,將所有的html標(biāo)簽替換成p標(biāo)簽,來說明捕獲到的分組怎么去引用。
首先我們分析一下這個匹配的規(guī)則,開始標(biāo)簽為<字符串>,結(jié)束標(biāo)簽為字符串>,我們只需要把這些替換為
就可以了。
var str = "1234456" var reg = /<(/?)(w+)>/g // 先匹配<,然后(/?)重復(fù)0或一次,然后匹配w+,匹配>,結(jié)束。 str.replace(reg, "<$1p>") // 字符串的替換方法,這里使用了$1,就是RegExp.$1,引用正則里面的分組(/?), // 所以<$1p>中的$1則為動態(tài)捕獲到的分組。當(dāng)標(biāo)簽為元素>時,RegExp.$1為/, // 字符串中用替換原來標(biāo)簽, // 則達(dá)到了將html字符串中開始標(biāo)簽和閉合標(biāo)簽全部替換的效果
捕獲型分組-反向引用
反向引用也是一樣將捕獲到的分組引用,不過是在編寫的正則里面,通過/1,/2,/3可以得到當(dāng)前捕獲到的分組.
非捕獲型分組
(?:)即表示該分組不能被捕獲,之后在引用的時候是引用不到這個分組的。
貪婪匹配和惰性匹配 正向前瞻和負(fù)向前瞻文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/53558.html
摘要:日常代碼的開發(fā)中,大家都或多或少的碰到一些正則表達(dá)式,但有的朋友只是會用,或者大致明白,希望這篇對正則深入淺出的文章能夠讓大家有所收獲。主要可以干的事情有兩個,引用和反向引用,在一些稍微復(fù)雜的正則表達(dá)式里,我們常常會用到這些。 日常代碼的開發(fā)中,大家都或多或少的碰到一些正則表達(dá)式,但有的朋友只是會用,或者大致明白,希望這篇對正則深入淺出的文章能夠讓大家有所收獲。 基本語法 [xyz] ...
摘要:日常代碼的開發(fā)中,大家都或多或少的碰到一些正則表達(dá)式,但有的朋友只是會用,或者大致明白,希望這篇對正則深入淺出的文章能夠讓大家有所收獲。主要可以干的事情有兩個,引用和反向引用,在一些稍微復(fù)雜的正則表達(dá)式里,我們常常會用到這些。 日常代碼的開發(fā)中,大家都或多或少的碰到一些正則表達(dá)式,但有的朋友只是會用,或者大致明白,希望這篇對正則深入淺出的文章能夠讓大家有所收獲。 基本語法 [xyz] ...
摘要:整個引擎實現(xiàn)只有不到行代碼。不知道你有木有聽說過一個基于的頁面預(yù)處理器,叫做。最初我只是打算寫一個的預(yù)處理器,不過后來擴(kuò)展到了和,可以用來把代碼轉(zhuǎn)成和代碼。最后一個改進(jìn)可以使我們的模板引擎更為強(qiáng)大。 導(dǎo)讀:AbsurdJS 作者寫的一篇教程,一步步教你怎樣用 Javascript 實現(xiàn)一個純客戶端的模板引擎。整個引擎實現(xiàn)只有不到 20 行代碼。如果你能從頭看到尾的話,還能有不少收獲的。...
閱讀 1964·2021-11-16 11:45
閱讀 3680·2021-09-06 15:02
閱讀 2025·2019-08-30 15:44
閱讀 2291·2019-08-30 11:21
閱讀 1854·2019-08-29 16:31
閱讀 3427·2019-08-29 13:55
閱讀 1900·2019-08-29 12:15
閱讀 3255·2019-08-28 18:05