站長資訊網
        最全最豐富的資訊網站

        JS正則中的match與exec使用說明

        主要參考W3C教程

        String.match()

        match() 方法將檢索目標字符串,以找到一個或多個與 正則表達式regexp 匹配的文本。match()有兩種情況:

        <!–[if !supportLists]–>1、 <!–[endif]–>如果 regexp 具有標志 g,則 match() 方法將執行全局檢索,找到目標字符串中的所有匹配子字符串。

        匹配情況

        返回值

        沒有找到任何匹配的子串

        null

        找到了一個或多個匹配子串

        一個數組。數組的內容包含所有的匹配子串

        下面是個實例:

        復制代碼 代碼如下:
        var str = ‘xxtest00test11test22test’
        regexp = new RegExp(/(test)(.{1})/g);
        while((result = regexp.exec(str)) != null){
        document.write(result + ‘<br />’);
        document.write(regexp.lastIndex+ ‘<br />’);
        }

        匹配的結果如下:

        返回的匹配數組:

        [testaa,testbb,testcc]
        并且數組不包含其他有關匹配的信息:

           0:testaa
           1:testbb
           2:testcc

        <!–[if !supportLists]–>2、 <!–[endif]–>如果 regexp 沒有標志 g,那么 match() 方法就只能目標字符串中執行一次匹配。

        匹配情況

        返回值

        沒有找到任何匹配的子串

        null

        找到了一個或多個匹配子串

        一個數組。數組的內容包含與它找到的匹配文本有關的信息。該數組的第 0 個元素存放的是匹配文本,而其余的元素存放的是與正則表達式的子表達式匹配的文本。除了這些常規的數組元素之外,返回的數組還含有兩個對象屬性。index 屬性聲明的是匹配文本的起始字符在目標字符串中的位置,input 屬性聲明的是對目標字符串的引用。

        我們把上面例子的全局標志g拿掉,regexp = new RegExp(/(test)(.{1})/);再次得到的匹配結果如下:

        返回的匹配數組:

        [test0,test,0]
        并且數組包含indexinput信息:

        0:test0
        1:test
        2:0
        index:2
        input:xxtest0test1test2test

        不過有一點需要說明的是,在IE6,7,8下,返回的數組同時包含lastIndex信息,用來表示表示匹配子串的下一個位置。話說這個屬性應該是在regexp上面的,所以在IE9里面去掉了。

        String.exec()方法:

        <!–[if !supportLists]–>1、 <!–[endif]–>如果 regexp 不具有標志 g

        匹配情況

        返回值

        沒有找到任何匹配的子串

        null

        找到了一個或多個匹配子串

        一個數組。數組的內容與調用match() 返回的數組是相同的。

        沿用上面的例子:

        復制代碼 代碼如下:
        result = regexp.exec(str);

        返回的匹配數組:
        [test0,test,0]
        并且數組包含index和input信息:
        0:test0
        1:test
        2:0
        index:2
        input:xxtest0test1test2test
        同樣,在IE6,7,8下,返回的數組同時包含lastIndex信息。
        <!–[if !supportLists]–>2、 <!–[endif]–>如果 regexp 具有標志 g。
        它會在 regexp的 lastIndex 屬性指定的字符處開始檢索。當 exec() 找到了與表達式相匹配的文本時,在匹配后,它將把 regexp的 lastIndex 屬性設置為匹配文本的最后一個字符的下一個位置。這就是說,可以通過反復調用 exec() 方法來遍歷字符串中的所有匹配文本。當 exec() 再也找不到匹配的文本時,它將返回 null,并把 lastIndex 屬性重置為 0。
        注:無論 RegExpObject 是否是全局模式,exec() 都會把完整的細節添加到它返回的數組中。這就是 exec() 與 match() 的不同之處,后者在全局模式下返回的信息要少得多。如果要獲得所有的匹配細節,就可以在全局模式下循環調用exec()方法。
        類似:

        復制代碼 代碼如下:
        var str = ‘xxtest00test11test22test’
        regexp = new RegExp(/(test)(.{1})/g);
        while((result = regexp.exec(str)) != null){
        document.write(result + ‘<br />’);
        document.write(regexp.lastIndex+ ‘<br />’);
        }

        對于lastIndex屬性的說明:
        <!–[if !supportLists]–>(1) <!–[endif]–>lastIndex在regexp上面,而不是返回的數組結果里面,IE6,7,8在match()方法的lastIndex實現上有bug。
        <!–[if !supportLists]–>(2) <!–[endif]–>如果在一個字符串中完成了一次模式匹配之后要開始檢索新的字符串,就必須手動地把 lastIndex 屬性重置為 0。

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国产亚洲欧美精品永久| 国产精品美女久久久m| 日韩精品无码免费视频| 99精品视频在线| 午夜精品久久久久久| 亚洲精品免费观看| 久久精品中文闷骚内射| 国产精品亚洲不卡一区二区三区| 精品成在人线AV无码免费看| 久久亚洲中文字幕精品一区| 1区1区3区4区产品芒果精品| 国产产无码乱码精品久久鸭| 欧美日韩精品一区二区视频 | 亚洲一区精品伊人久久伊人| 在线精品视频播放| 国产精品天天看天天狠| 亚洲国产精品13p| 国产色婷婷精品综合在线| 欧美精品/日韩精品/国产精品| 国产精品三级在线观看无码| 亚洲av永久无码精品秋霞电影影院 | 青青青国产依人精品视频 | 精品亚洲成AV人在线观看| 黑人巨茎精品欧美一区二区| 国产精品自产拍在线观看| 久久精品99久久香蕉国产色戒| 亚洲精品成人网站在线观看| 亚洲国产精品成人网址天堂 | 国产精品主播一区二区| 国产福利电影一区二区三区,亚洲国模精品一区 | 国产精品亚洲精品日韩已方| 精品国产日产一区二区三区| 99精品高清视频一区二区| 精品久久久无码人妻中文字幕豆芽 | 国产精品白丝jkav网站| 免费看一级毛片在线观看精品视频| 国产精品久久久久AV福利动漫| 少妇人妻无码精品视频| 无码国产亚洲日韩国精品视频一区二区三区| 国产日韩精品欧美一区喷水| 香蕉依依精品视频在线播放 |