詳解JavaScript正則表達式之分組匹配及反向引用
來源:易賢網(wǎng) 閱讀:1135 次 日期:2016-07-21 15:27:24
溫馨提示:易賢網(wǎng)小編為您整理了“詳解JavaScript正則表達式之分組匹配及反向引用”,方便廣大網(wǎng)友查閱!

這篇文章主要介紹了詳解JavaScript正則表達式之分組匹配及反向引用 的相關(guān)資料,需要的朋友可以參考下

語法

元字符:(pattern)  作用:用于反復匹配的分組

屬性$1~$9  如果它(們)存在,用于得到對應分組中匹配到的子串 

\1或$1  用于匹配第一個分組中的內(nèi)容

\2或$2  用于匹配第一個分組中的內(nèi)容

...

\9或$9  用于匹配第一個分組中的內(nèi)容

用法示例

var reg = /(A+)((B|C|D)+)(E+)/gi;//該正則表達式有4個分組

//對應關(guān)系

//RegExp.$1 <-> (A+)

//RegExp.$2 <-> ((B|C|D)+)

//RegExp.$3 <-> (B|C|D)

//RegExp.$4 <-> (E+)

以上的代碼也同時給出了$1~$9的用法

$1~$9是正則表達式預定義的靜態(tài)屬性,通過RegExp.$1引用

分組嵌套關(guān)系說明

上述代碼也可以說明分組的嵌套關(guān)系

//測試環(huán)境 Chrome瀏覽器

var str = "ABCDE";

var reg = /(A+)((B|C|D)+)(E+)/gi;

str.match(reg);//輸出:["ABCDE"]

reg.exec(str,'i');//輸出:["ABCDE", "A", "BCD", "D", "E"]

RegExp.$1;//輸出:"A"

RegExp.$2;//輸出:"BCD"

RegExp.$3;//輸出:"D"

RegExp.$4;//輸出:"E"

這樣就可以很明白的看出分組的嵌套關(guān)系了

總結(jié)來說:大的分組中存在小的分組時,小的分組是排在該大分組后面的分組,以此類推

第二部分

這部分主要講解類似于"\1"這個東西的用法

分組匹配之反向引用

語法

元字符 \1~\9  作用:用來表示前面以匹配的字符或分組的一個引用

用法示例

上面說的可能有些拗口,下面給一個例子:

//一般情況,當我們想匹配任意兩個相同的字符(復雜一點就是兩個相同的分組)時,往往可以借助下面的寫法

//說明:

//(\w)用來匹配任何除了換行和制表符的字符, 而\1是對(\w)的一個引用, 所以你可以理解成: (\w)\1 就是(\w)(\w)

//但是,

//(\w)\1 和 (\w)(\w)的不同之處在于, (\w)(\w)表示任意兩個連續(xù)的字符, 比如Ac, MM, K9, 都可以,

// 但(\w)\1只能是AA, CC, 99 這樣連續(xù)相同的字符

//所以, 你可以這樣理解, \1 是對(\w)的一個實例化引用, 當(\w) 匹配到A時, \1 被表達成A, 當(\w)匹配9時, \1 被表示成9

//說了這么多, 可能有些廢話, 下面這個例子就很好理解了

var str = "AA Am 99";

var reg = /(\w)\1/g;

str.match(reg);//輸出: ["AA", "99"]

所以, 參照上邊我所引用的文章中給出的 "關(guān)鍵字搜索高亮顯示的正則表達用法" 的例子, 我給出自己改進的小的DEMO

雖然這個DEMO沒有用到任何的關(guān)于反向引用的知識點::>_<::

//測試環(huán)境 Chrome瀏覽器

var key = "keywords";//搜索的關(guān)鍵字

var text = " I am a text, and I have a keywords before this";//待匹配的文本

var reg = new RegExp("("+key+")","g");

text.replace(reg,"<span style='color:red'>$1</span>");//輸出: " I am a text, and I have a <span style='color:red'>keywords</span> before this"

下面給大家詳細介紹下正則表達式之反向引用

示例1:

public static void main(String[] args) { 

 String s="99-3933"; 

 boolean b=Pattern.matches("([\\d])\\1[-]([3])\\1\\2{2}", s); 

 System.out.println(b); 

}

反向引用,匹配重復的數(shù)字

([\d])====>\1

([3])====>\2

示例2:

public class test { 

 public static void main(String[] args) { 

  String s="99-393399-3933"; 

  boolean b=Pattern.matches("(([\\d])\\2[-]([3])\\2\\3{2})\\1", s); 

  System.out.println(b); 

 } 

}

更多信息請查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機網(wǎng)站地址:詳解JavaScript正則表達式之分組匹配及反向引用

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)