摘要:但不管是那種匹配都必須保證匹配滿足正則表達式基本條件。在正則表達式中,通過分組可以在一個完整的模式中定義子模式。在同一個正則表達式的后部分可以引用前面的子表達式。
預(yù)定義字符類
.(點好): 匹配除了換行符和其他Unicode行終止符(如回車符)之外的任意字符,等價于[^ ] w: 匹配任何ASII單字字符,等價于[a-zA-Z0-9_] W: 匹配任何非ASII單字字符,等價于[^a-zA-Z0-9_] s: 匹配任何Unicode空白符,等價于[ x0Bf ]貪婪匹配
概念:如星號(*)元字符在執(zhí)行匹配時,先看整個字符串是否匹配,如果不匹配則去掉該字符串中的最后一個字符,并再次嘗試。
1.?、{n}和{n,m}重復(fù)類
這三個都具有弱貪婪性,主要表現(xiàn)在貪婪性具有有限性。對于?匹配,在選擇匹配還是不匹配時,如果條件允許,它總是會選擇匹配而不是不匹配;{n,m}在條件允許的情況下,匹配m次,而不是n次。 正則式的貪婪性是在遵循匹配條件基礎(chǔ)上盡可能占有更多的字符,而不是隨意占用。
2.*、+和{n,}重復(fù)類
這三個具有強貪婪性,這種貪婪表現(xiàn)為貪婪的無限性
星號(*)重復(fù)類的匹配底線是最寬容的,匹配欲望是最強烈的。不管是否存在指定字符或子表達式都會執(zhí)行匹配操作
加號(+)重復(fù)類的匹配底線是最少存在一個符合指定條件的字符或子表達式,否則不予執(zhí)行匹配操作
{n,}重復(fù)類的匹配底線是最靈活的,執(zhí)行任意底線和條件的無限貪婪的匹配操作。
正則表達式是有貪婪性的,它總是與最長的長度匹配,而且越是排在左側(cè)的重復(fù)類匹配符優(yōu)先級就越高。
var s = ""; var r = /(<.*>)(<.*>)/ var a = s.match(r); alert(a[1])// alert(a[2])//
上面的演示說明,當(dāng)多個重復(fù)類并列子在一起時,左側(cè)重復(fù)類具有較大的優(yōu)先權(quán),并盡可能的占有更多的符合條件的字符。
惰性匹配惰性匹配它將先查看字符串中的第一個字符是否匹配,如果匹配條件不夠,就讀入下一個字符。如果還是匹配不足夠,惰性匹配會繼續(xù)從字符串中讀取字符串直到發(fā)現(xiàn)匹配或者整個字符串都檢查過也沒有匹配為止。惰性匹配只需要在重復(fù)類后面添加問號(?)就可以了。問號必須放在重復(fù)字符串后面。
貪婪匹配體現(xiàn)了最大化匹配原則,那么惰性匹配體現(xiàn)了最小化匹配原則。但不管是那種匹配都必須保證匹配滿足正則表達式基本條件。
{n,m}?: 正則表達式盡量匹配n次,但是為了滿足匹配條件也可能最多重復(fù)m次
{n}?: 正則表達式盡量匹配n次;
{n,}?: 盡量匹配n次,但為了滿足匹配條件也可能匹配任意次
??: 正則表達式盡量匹配,但是為了滿足匹配條件也可能多次匹配1次,相當(dāng)于{0,1}?
+?: 盡量匹配1次,但是為了滿足匹配條件也可能匹配任意次數(shù),相當(dāng)于{1,}?
*?:相當(dāng)于{0,}?
支配匹配(瀏覽器兼容不強)這個是另一種類型的匹配模式,它的算法是:只匹配整個字符串。如果整個字符串不能匹配,則會自動放棄匹配,不再執(zhí)行迭代以求進一步嘗試。支配匹配只需要在重復(fù)類后面添加加號(+)即可。
高級匹配模式1.分組:就是通過用小括號來包含一系列字符、字符類,或者重復(fù)類量詞,以實現(xiàn)處理各種特殊的字符序列
通過小括號邏輯分隔符,實現(xiàn)分別儲存每個被匹配的標(biāo)簽,最后通過這個數(shù)組類獲取每個標(biāo)簽的名稱。小括號表示一個獨立的邏輯域,其匹配的內(nèi)容將被獨立存儲。
分組的應(yīng)用價值
把多帶帶的項目進行分組,以便合成子表達式,這樣就可以像處理yi個獨立的字符那樣,使用|、+、*或?等字符來處理他們。
在正則表達式中,通過分組可以在一個完整的模式中定義子模式。當(dāng)一個正在表達式成功地與目標(biāo)字符串匹配時,也可以從目標(biāo)字符串中抽出與小括號中的子模式相匹配的部分。
var s = "ab=21,bc=45,cd=43"; var r = /(w+)=(d+)/; var a = s.match(r); ["ab=21","ab","21"]
在同一個正則表達式的后部分可以引用前面的子表達式。這是通過在字符“”后加一位或多位數(shù)字實現(xiàn)的。數(shù)字指定了帶括號的子表達式在正則表達式中的位置
var s = "非引用型分組title
text
" var r = /(?w+>).*1/g; var a = s.match(r);//["title
","text
"]
正則表達式分組會占用一定的系統(tǒng)資源,在較長的正則表達式中,存儲反向引用會降低匹配速度。創(chuàng)建非引用型分組的方法是,在括號的后面分別加上一個問號和冒號。(?:w*?)
聲明正則表達式用來聲明正則表達式在什么條件下才能匹配,或者不在什么條件下才會匹配,這種聲明包括正前向聲明和反向前聲明兩種模式
正前向聲明是指匹配模式后面的字符,聲明表示條件的意思,也是指定在接下來的字符必須被匹配,但并不真正進行匹配。通俗的講,就是指定可能執(zhí)行匹配操作的條件,該條件作為正則表達式的匹配模式一部分而存在,但是不會真正使用該條件去執(zhí)行匹配。
var s = "a:123 b=345"; var r = /w*(?==)/; var a = s.match(r);//["b"]
反前向聲明,就是指定接下來的字符都不必匹配,反前向聲明使用“(?!匹配條件)”來表示
var s = "a:123 b=345"; var r = /w*(?!=)/; var a = s.match(r);//["a"]靜態(tài)
var s = "JavaScript, not Javascript"; var r = /(Java)Script/gi; var a = r.exec(s); RegExp.input//"JavaScript, not Javascript" RegExp.leftContext//空字符串 RegExp.rightContext//", not Javascript" RegExp.lastMatch//"JavaScript" RegExp.lastParen//"Java"
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/82634.html
摘要:正則表達式一直是里比較難以掌握的點。在中創(chuàng)建正則的兩種方式使用字面量這就是正則表達式的字面量語法,表示正則表達式的模式,為正則表達式的標(biāo)志。字面量形式的正則表達式一般使用較多,也推薦大家盡可能使用這種形式,簡潔易讀,符合正常的使用習(xí)慣。 正則表達式一直是js里比較難以掌握的點。 看不懂,學(xué)不會,記不住。 每次需要用到正則的時候,都需要再去查找資料。 今天花時間把正則的知識點總結(jié)下,希望...
摘要:選擇分組和引用正則表達式的語法還包括指定選擇項子表達式分組和引用前一子表達式的特殊字符。帶圓括號的表達式的另一個用途是允許在同一正則表達式的后部引用前面的子表達式。 正則表達式(regular expression)是一個描述字符模式的對象。JavaScript的 RegExp類 表示正則表達式,String和RegExp都定義了方法,后者使用正則表達式進 行強大的模式匹配和文本檢索與...
閱讀 1181·2023-04-26 02:42
閱讀 1633·2021-11-12 10:36
閱讀 1780·2021-10-25 09:47
閱讀 1262·2021-08-18 10:22
閱讀 1801·2019-08-30 15:52
閱讀 1213·2019-08-30 10:54
閱讀 2635·2019-08-29 18:46
閱讀 3496·2019-08-26 18:27