摘要:執(zhí)行全局匹配查找所有匹配而非在找到第一個(gè)匹配后停止。標(biāo)識(shí)一個(gè)八進(jìn)制轉(zhuǎn)義值或一個(gè)向后引用。例不能匹配中的,但是能匹配中的兩個(gè)是一個(gè)非負(fù)整數(shù)。和均為非負(fù)整數(shù),其中。匹配任何不在指定范圍內(nèi)的任意字符。否則,將視為一個(gè)原義的字符。
修飾符:
i: 執(zhí)行對大小寫不敏感的匹配。 g: 執(zhí)行全局匹配(查找所有匹配而非在找到第一個(gè)匹配后停止)。 m: 執(zhí)行多行匹配。元字符:
d: 匹配一個(gè)數(shù)字字符。等價(jià)于 [0-9]。 D: 匹配一個(gè)非數(shù)字字符。等價(jià)于 [^0-9]。 f: 匹配一個(gè)換頁符。等價(jià)于 x0c 和 cL。 : 匹配一個(gè)換行符。等價(jià)于 x0a 和 cJ。 : 匹配一個(gè)回車符。等價(jià)于 x0d 和 cM。 s: 匹配任何空白字符,包括空格、制表符、換頁符等等。等價(jià)于 [ f v]。 S: 匹配任何非空白字符。等價(jià)于 [^ f v]。 : 匹配一個(gè)制表符。等價(jià)于 x09 和 cI。 v: 匹配一個(gè)垂直制表符。等價(jià)于 x0b 和 cK。 w: 匹配字母、數(shù)字、下劃線。等價(jià)于"[A-Za-z0-9_]"。 W: 匹配非字母、數(shù)字、下劃線。等價(jià)于 "[^A-Za-z0-9_]"。 xn: 匹配 n,其中 n 為十六進(jìn)制轉(zhuǎn)義值。十六進(jìn)制轉(zhuǎn)義值必須為確定的兩個(gè)數(shù)字長。 例: "x41" 匹配 "A"。"x041" 則等價(jià)于 "x04" & "1"。正則表達(dá)式中可以使用 ASCII 編碼。 um: 匹配 num,其中 num 是一個(gè)正整數(shù)。對所獲取的匹配的引用。 例: "(.)1" 匹配兩個(gè)連續(xù)的相同字符。 : 標(biāo)識(shí)一個(gè)八進(jìn)制轉(zhuǎn)義值或一個(gè)向后引用。如果 之前至少 n 個(gè)獲取的子表達(dá)式,則 n 為向后引用。否則,如果 n 為八進(jìn)制數(shù)字 (0-7),則 n 為一個(gè)八進(jìn)制轉(zhuǎn)義值。 m: 標(biāo)識(shí)一個(gè)八進(jìn)制轉(zhuǎn)義值或一個(gè)向后引用。如果 m 之前至少有 nm 個(gè)獲得子表達(dá)式,則 nm 為向后引用。如果 m 之前至少有 n 個(gè)獲取,則 n 為一個(gè)后跟文字 m 的向后引用。如果前面的條件都不滿足,若 n 和 m 均為八進(jìn)制數(shù)字 (0-7),則 m 將匹配八進(jìn)制轉(zhuǎn)義值 nm ml: 如果 n 為八進(jìn)制數(shù)字 (0-3),且 m 和 l 均為八進(jìn)制數(shù)字 (0-7),則匹配八進(jìn)制轉(zhuǎn)義值 nml un: 匹配 n,其中 n 是一個(gè)用四個(gè)十六進(jìn)制數(shù)字表示的 Unicode 字符。 例: u00A9 匹配版權(quán)符號(hào) (?)。 : 將下一個(gè)字符標(biāo)記為一個(gè)特殊字符、或一個(gè)原義字符、或一個(gè) 向后引用、或一個(gè)八進(jìn)制轉(zhuǎn)義符。 例:"n" 匹配字符 "n"。" " 匹配一個(gè)換行符。序列 "" 匹配 "" 而 "(" 則匹配 "("。 ^: 匹配輸入字符串的開始位置。如果設(shè)置了 RegExp 對象的 Multiline 屬性,^ 也匹配 " " 或 " " 之后的位置。 例: (^a) 就是匹配以字母a開頭的字符串 ^: 還有另個(gè)一個(gè)作用就是取反,比如[^xyz] 表示匹配的字符串不包含xyz 例: [^xyz] 表示匹配的字符串不包含xyz $: 匹配輸入字符串的結(jié)束位置。如果設(shè)置了RegExp 對象的 Multiline 屬性,$ 也匹配 " " 或 " " 之前的位置。 例: (b$) 就是匹配以字母b結(jié)尾的字符串 *: 匹配前面的子表達(dá)式零次或多次。 例: zo* 能匹配 "z" 以及 "zoo"。* 等價(jià)于{0,}。 +: 匹配前面的子表達(dá)式一次或多次。 例: "zo+" 能匹配 "zo" 以及 "zoo",但不能匹配 "z"。+ 等價(jià)于 {1,}。 ?: 匹配前面的子表達(dá)式零次或一次。 例: "do(es)?" 可以匹配 "do" 或 "does" 。? 等價(jià)于 {0,1}。 ?: 當(dāng)該字符緊跟在任何一個(gè)其他限制符 (*, +, ?, {n}, {n,}, {n,m}) 后面時(shí),匹配模式是非貪婪的。非貪婪模式盡可能少的匹配所搜索的字符串,而默認(rèn)的貪婪模式則盡可能多的匹配所搜索的字符串。 例: 對于字符串 "oooo","o+?" 將匹配單個(gè) "o",而 "o+" 將匹配所有 "o"。 {n}: n 是一個(gè)非負(fù)整數(shù)。匹配確定的 n 次。 例: "o{2}" 不能匹配 "Bob" 中的 "o",但是能匹配 "food" 中的兩個(gè) o {n,}: n 是一個(gè)非負(fù)整數(shù)。至少匹配n 次。 例: "o{2,}" 不能匹配 "Bob" 中的 "o",但能匹配 "foooood" 中的所有 o。"o{1,}" 等價(jià)于 "o+"。"o{0,}" 則等價(jià)于 "o*"。 {n,m}: m 和 n 均為非負(fù)整數(shù),其中n <= m。最少匹配 n 次且最多匹配 m 次。 例: "o{1,3}" 將匹配 "fooooood" 中的前三個(gè) o。"o{0,1}" 等價(jià)于 "o?"。請注意在逗號(hào)和兩個(gè)數(shù)之間不能有空格。 .: 匹配除 " " 之外的任何單個(gè)字符。要匹配包括 " " 在內(nèi)的任何字符,請使用像"(.| )"的模式。 (pattern): 匹配 pattern 并獲取這一匹配。所獲取的匹配可以從產(chǎn)生的 Matches 集合得到,在VBScript 中使用 SubMatches 集合,在JScript 中則使用 $0…$9 屬性。要匹配圓括號(hào)字符,請使用 "(" 或 ")" 例:"(x)" 將匹配到 "x" 并將按順序從 $1-$99 排序代替 例: var url = "http://www.qidian.com/BookReader/1017141,20361055.aspx" var reg = /(http://www.qidian.com/BookReader/)(d+),(d+).aspx/gmi var rep=url.replace(reg,"$1ShowBook.aspx?bookId=$2&chapterId=$3"); console.log(rep); // -> http://www.qidian.com/BookReader/ShowBook.aspx?bookId=1017141&chapterId=20361055 (?:pattern):匹配 pattern 但不獲取匹配結(jié)果,也就是說這是一個(gè)非獲取匹配,不進(jìn)行存儲(chǔ)供以后使用。這在使用 "或" 字符 (|) 來組合一個(gè)模式的各個(gè)部分是很有用。 例:"industr(?:y|ies) 就是一個(gè)比 "industry|industries" 更簡略的表達(dá)式。 (?=pattern): 正向肯定預(yù)查(look ahead positive assert),在任何匹配pattern的字符串開始處匹配查找字符串。這是一個(gè)非獲取匹配,也就是說,該匹配不需要獲取供以后使用。 例: "Windows(?=95|98|NT|2000)"能匹配"Windows2000"中的"Windows",但不能匹配"Windows3.1"中的"Windows"。預(yù)查不消耗字符,也就是說,在一個(gè)匹配發(fā)生后,在最后一次匹配之后立即開始下一次匹配的搜索,而不是從包含預(yù)查的字符之后開始。 (?!pattern): 正向否定預(yù)查(negative assert),在任何不匹配pattern的字符串開始處匹配查找字符串。這是一個(gè)非獲取匹配,也就是說,該匹配不需要獲取供以后使用。 例: "Windows(?!95|98|NT|2000)"能匹配"Windows3.1"中的"Windows",但不能匹配"Windows2000"中的"Windows"。預(yù)查不消耗字符,也就是說,在一個(gè)匹配發(fā)生后,在最后一次匹配之后立即開始下一次匹配的搜索,而不是從包含預(yù)查的字符之后開始。 (?<=pattern): 反向(look behind)肯定預(yù)查,與正向肯定預(yù)查類似,只是方向相反。 例: "(?<=95|98|NT|2000)Windows"能匹配"2000Windows"中的"Windows",但不能匹配"3.1Windows"中的"Windows"。 (? 方法1.compile(regexp,modifier): 在腳本執(zhí)行過程中編譯正則表達(dá)式
/* regexp: 正則表達(dá)式 modifier: 規(guī)定匹配的類型。"g" 用于全局匹配,"i" 用于區(qū)分大小寫,"gi" 用于全局區(qū)分大小寫的匹配。 */ var compileStr = "Every man in the world! Every woman on earth!"; var compilePatt = /man/g; var compilePatt1 = /(wo)?man/g; compilePatt1.compile(compilePatt1) var compileStrEle1 = compileStr.replace(compilePatt,"person"); var compileStrEle2 = compileStr.replace(compilePatt1,"person"); console.log(compileStrEle1) // -> Every person in the world! Every woperson on earth! console.log(compileStrEle2) // -> Every person in the world! Every person on earth!2.exec(string): 用于檢索字符串中的正則表達(dá)式的匹配。如果字符串中有匹配的值返回該匹配值,否則返回 null。
var execStr = "Hello world!"; var execPatt = /Hello/g; var execStrEle = execPatt.exec(execStr); console.log(execStrEle) // -> Hello3.test(string): 用于檢測一個(gè)字符串是否匹配某個(gè)模式.如果字符串中有匹配的值返回 true ,否則返回 false
var testStr = "Hello world!"; var testPatt = /Hello/g; var testPatt2 = /Helloaaa/g; var testStrEle = testPatt.test(testStr); var testStrEle2 = testPatt2.test(testStr); console.log(testStrEle) // -> true console.log(testStrEle2) // -> false4.match(regexp): 可在字符串內(nèi)檢索指定的值,或找到一個(gè)或多個(gè)正則表達(dá)式的匹配。如果沒有找到任何匹配的文本, match() 將返回 null。否則,它將返回一個(gè)數(shù)組,其中存放了與它找到的匹配文本有關(guān)的信息。
var matchStr = "The rain in SPAIN stays mainly in the plain"; var matchEle = matchStr.match(/ain/gi); console.log(matchEle) // -> ["ain", "AIN", "ain", "ain"]常見正則表達(dá)式匯總/^[1-9]d*$/ //匹配正整數(shù) /^-[1-9]d*$/ //匹配負(fù)整數(shù) /^-?[1-9]d*$/ //匹配整數(shù) /^[1-9]d*|0$/ //匹配非負(fù)整數(shù)(正整數(shù) + 0) /^-[1-9]d*|0$/ //匹配非正整數(shù)(負(fù)整數(shù) + 0) /^[1-9]d*.d*|0.d*[1-9]d*$/ //匹配正浮點(diǎn)數(shù) /^-([1-9]d*.d*|0.d*[1-9]d*)$/ //匹配負(fù)浮點(diǎn)數(shù) /^-?([1-9]d*.d*|0.d*[1-9]d*|0?.0+|0)$/ //匹配浮點(diǎn)數(shù) /^[1-9]d*.d*|0.d*[1-9]d*|0?.0+|0$/ //匹配非負(fù)浮點(diǎn)數(shù)(正浮點(diǎn)數(shù) + 0) /^(-([1-9]d*.d*|0.d*[1-9]d*))|0?.0+|0$/ //匹配非正浮點(diǎn)數(shù)(負(fù)浮點(diǎn)數(shù) + 0) /^[A-Za-z]+$/ // 由26個(gè)英文字母組成的字符串 /^[A-Z]+$/ // 由26個(gè)英文字母的大寫組成的字符串 /^[a-z]+$/ // 由26個(gè)英文字母的小寫組成的字符串 /^[A-Za-z0-9]+$/ // 由數(shù)字和26個(gè)英文字母組成的字符串 /^w+$/ // 由數(shù)字、26個(gè)英文字母或者下劃線組成的字符串 /^[x00-xff]+$/ // 匹配所有單字節(jié)長度的字符組成的字符串 /^[^x00-xff]+$/ // 匹配所有雙字節(jié)長度的字符組成的字符串 /[^x00-xff]+/ // 字符串是否含有雙字節(jié)字 /n[s| ]*r/ // 匹配空行的正則 /(^s*)|(s*$)/ // 匹配首尾空格的正則 /^[a-zA-Z0-9_]{1,}$/ // 所有包含一個(gè)以上的字母、數(shù)字或下劃線的字符串 /[^""]/ // 除了雙引號(hào)(")和單引號(hào)(")之外的所有字符檢測函數(shù)function checkStr (str, type) { switch (type) { case "phone": //手機(jī)號(hào)碼 return /^1[3|4|5|7|8][0-9]{9}$/.test(str); case "tel": //座機(jī) return /^(0d{2,3}-d{7,8})(-d{1,4})?$/.test(str); case "card": //身份證 return /^d{15}|d{18}$/.test(str); case "pwd": //密碼以字母開頭,長度在6~18之間,只能包含字母、數(shù)字和下劃線 return /^[a-zA-Z]w{5,17}$/.test(str) case "postal": //郵政編碼 return /[1-9]d{5}(?!d)/.test(str); case "QQ": //QQ號(hào) return /^[1-9][0-9]{4,9}$/.test(str); case "email": //郵箱 return /^[w-]+(.[w-]+)*@[w-]+(.[w-]+)+$/.test(str); case "money": //金額(小數(shù)點(diǎn)2位) return /^d*(?:.d{0,2})?$/.test(str); case "URL": //網(wǎng)址 return /(http|ftp|https)://[w-_]+(.[w-_]+)+([w-.,@?^=%&:/~+#]*[w-@?^=%&/~+#])?/.test(str) case "IP": //IP return /((?:(?:25[0-5]|2[0-4]d|[01]?d?d).){3}(?:25[0-5]|2[0-4]d|[01]?d?d))/.test(str); case "date": //日期時(shí)間 return /^(d{4})-(d{2})-(d{2}) (d{2})(?::d{2}|:(d{2}):(d{2}))$/.test(str) || /^(d{4})-(d{2})-(d{2})$/.test(str) case "number": //數(shù)字 return /^[0-9]$/.test(str); case "english": //英文 return /^[a-zA-Z]+$/.test(str); case "chinese": //中文 return /^[u4E00-u9FA5]+$/.test(str); case "lower": //小寫 return /^[a-z]+$/.test(str); case "upper": //大寫 return /^[A-Z]+$/.test(str); case "HTML": //HTML標(biāo)記 return /<("[^"]*"|"[^"]*"|[^"">])*>/.test(str); default: return true; } }博客地址:javascript 總結(jié)(RegExp篇)
github: javascript 總結(jié)(RegExp篇)
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/90662.html
摘要:操作符還有可能是設(shè)計(jì)中最大缺陷,因?yàn)樗鼛缀跏峭耆茡p的。由于用法與調(diào)用函數(shù)的語法相似,因此常被誤以為是函數(shù)調(diào)用,實(shí)際上并不存在名為的函數(shù),只是一個(gè)操作符而已。而列則表示對象內(nèi)部的屬性。屬性文檔中明確地給出了獲得屬性的途徑,就是使用。 typeof 操作符(還有 instanceof)可能是 Javascript 設(shè)計(jì)中最大缺陷,因?yàn)樗鼛缀跏峭耆茡p的。由于 typeof 用法與調(diào)用函數(shù)...
摘要:基礎(chǔ)語法鞏固正則表達(dá)式引擎根據(jù)正則去匹配字符的時(shí)候,是通過檢查索引的方式。妻原配就是好,可以直接使用正則表達(dá)式調(diào)用它。下面解釋一下上面這些常用的元字符查找單個(gè)字符,除了換行和行結(jié)束符。正則系列文章整理到了 上一章內(nèi)容:正則表達(dá)式實(shí)戰(zhàn)篇 知識(shí)回顧 前2章分別學(xué)習(xí)了正則表達(dá)式入門技巧,以及遇到正則需求該如何去分析問題,還有正則表達(dá)式實(shí)戰(zhàn)的一些場景解釋。 這一章內(nèi)容偏向理論,推薦你點(diǎn)擊開頭的...
摘要:用來檢測數(shù)據(jù)類型的運(yùn)算符語法雖然是基本數(shù)據(jù)類型值,但是它屬于空對象指針,檢測的結(jié)果是對象使用有自己的局限性,不能具體細(xì)分當(dāng)前的值是數(shù)組還是正則也就是不能細(xì)分對象類型的值先算檢測某一個(gè)實(shí)例是否屬于某各類的實(shí)例構(gòu)造函數(shù)使用檢測某個(gè)值是否屬于某 typeof 用來檢測數(shù)據(jù)類型的運(yùn)算符語法:typeof[value] typeof 12 //=>number typeof NaN //=>nu...
摘要:特意對前端學(xué)習(xí)資源做一個(gè)匯總,方便自己學(xué)習(xí)查閱參考,和好友們共同進(jìn)步。 特意對前端學(xué)習(xí)資源做一個(gè)匯總,方便自己學(xué)習(xí)查閱參考,和好友們共同進(jìn)步。 本以為自己收藏的站點(diǎn)多,可以很快搞定,沒想到一入?yún)R總深似海。還有很多不足&遺漏的地方,歡迎補(bǔ)充。有錯(cuò)誤的地方,還請斧正... 托管: welcome to git,歡迎交流,感謝star 有好友反應(yīng)和斧正,會(huì)及時(shí)更新,平時(shí)業(yè)務(wù)工作時(shí)也會(huì)不定期更...
閱讀 3295·2021-10-13 09:39
閱讀 2045·2021-09-27 13:36
閱讀 3115·2021-09-22 16:02
閱讀 2628·2021-09-10 10:51
閱讀 1606·2019-08-29 17:15
閱讀 1560·2019-08-29 16:14
閱讀 3544·2019-08-26 11:55
閱讀 2580·2019-08-26 11:50