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

        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日韩精品久久久久久| 国产精品偷窥熟女精品视频| 99国产精品久久| 无码人妻精品一区二区三区久久 | 欧洲精品99毛片免费高清观看| 无码精品人妻一区二区三区漫画| 91精品欧美综合在线观看| 国产精品乱伦| 成人区人妻精品一区二区不卡视频 | 久久国产精品国产自线拍免费| 亚洲AV永久精品爱情岛论坛| 久久国产精品偷99| 高清日韩精品一区二区三区| 国产精品久久亚洲不卡动漫| 精品久久久久久无码专区不卡| 亚洲精品专区| 久久青青草原精品国产软件| MM1313亚洲精品无码| 久久99精品国产一区二区三区| 97久久国产亚洲精品超碰热| 久久精品国产亚洲AV香蕉| 最新国产精品精品视频| 亚洲av无码成人精品区| 久久亚洲国产成人精品无码区| 国产精品亚洲综合专区片高清久久久| 国产精品福利一区二区| 国产精品女同久久久久电影院| 精品国产一区二区三区无码| 久久久久亚洲精品天堂| 久久久精品2019免费观看| 日韩精品系列产品| 三上悠亚久久精品| 日韩精品一区二区三区色欲AV | 久久精品国产亚洲网站| 国内精品91最新在线观看| 国产精品久久久久影院色| 精品亚洲欧美高清不卡高清| 久久99精品综合国产首页|