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

        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號
        主站蜘蛛池模板: 99熟女精品视频一区二区三区| 精品久久久久久无码免费| 中文字幕亚洲精品| 人人妻人人澡人人爽人人精品97| 国产精品乱伦| 久久精品国产精品国产精品污| 久久99国产综合精品女同| 亚洲A∨午夜成人片精品网站| 亚洲欧美日韩精品| 国产精品无码AV一区二区三区| 亚洲精品偷拍视频免费观看| 国产精品污WWW一区二区三区| 国产精品视频a播放| 国产精品三级国产电影| 亚洲精品无码成人AAA片| 欧美国产精品va在线观看| 国产色精品vr一区区三区| 91精品无码久久久久久五月天| 精品成人免费自拍视频| 99久久久精品| 国产99视频精品免费专区| 欧美肥屁VIDEOSSEX精品| 亚洲综合精品网站| 亚洲AV成人精品日韩一区18p| 久久久久国产精品三级网| 久久国产精品无码网站| 国产午夜福利精品久久| 国产精品成人一区二区| 91人前露出精品国产| 2021国产成人精品久久| 四虎影永久在线观看精品| 久久精品国产精品国产精品污| 九九在线精品视频专区| 久久精品一区二区三区不卡| 欧美亚洲国产成人精品| 欧美精品在线一区| 真实国产乱子伦精品免费| 国产精品午夜无码AV天美传媒| 国产精品热久久无码av| 精品福利一区二区三区精品国产第一国产综合精品 | 国产精品 视频一区 二区三区|