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

        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號
        主站蜘蛛池模板: 日韩精品一区二区三区视频| 久久水蜜桃亚洲av无码精品麻豆| 亚洲午夜国产精品无码老牛影视| 四虎国产精品免费久久5151| 亚洲国产精品乱码一区二区 | 国产亚洲精品a在线观看app| 在线观看自拍少妇精品| 国内精品久久久久久中文字幕| 精品免费视在线观看| 国自产偷精品不卡在线| 亚洲精品无码永久中文字幕| 久久精品亚洲乱码伦伦中文| 99精品视频在线观看婷| 国产精品一级香蕉一区| 国产精品偷伦视频观看免费 | 国产三级精品三级在线观看| 国产福利在线观看精品| 人妻少妇精品视中文字幕国语| 亚洲第一永久AV网站久久精品男人的天堂AV | 无码国产69精品久久久久网站| 香蕉99久久国产综合精品宅男自| 久久五月精品中文字幕| 久久亚洲av无码精品浪潮| 久久国产精品国语对白| 精品99久久aaa一级毛片| 国产精品无码免费播放| 国模精品一区二区三区| 国产精品午夜久久| 精品久久久久国产免费| 久久精品亚洲精品国产欧美| 欧美激情精品久久久久久久| 精品无码久久久久久国产 | 99精品视频在线观看| 97久久精品午夜一区二区| 国产福利91精品一区二区三区| 国产99re在线观看只有精品| 91精品一区国产高清在线| 国产精品久久精品| 51精品资源视频在线播放| 国产精品乱码一区二区三区| 精品久久久久久久久久中文字幕 |