欧美亚洲中文,在线国自产视频,欧洲一区在线观看视频,亚洲综合中文字幕在线观看

      1. <dfn id="rfwes"></dfn>
          <object id="rfwes"></object>
        1. 站長(zhǎng)資訊網(wǎng)
          最全最豐富的資訊網(wǎng)站

          JS正則中的match與exec使用說(shuō)明

          主要參考W3C教程

          String.match()

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

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

          匹配情況

          返回值

          沒(méi)有找到任何匹配的子串

          null

          找到了一個(gè)或多個(gè)匹配子串

          一個(gè)數(shù)組。數(shù)組的內(nèi)容包含所有的匹配子串

          下面是個(gè)實(shí)例:

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

          匹配的結(jié)果如下:

          返回的匹配數(shù)組:

          [testaa,testbb,testcc]
          并且數(shù)組不包含其他有關(guān)匹配的信息:

             0:testaa
             1:testbb
             2:testcc

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

          匹配情況

          返回值

          沒(méi)有找到任何匹配的子串

          null

          找到了一個(gè)或多個(gè)匹配子串

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

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

          返回的匹配數(shù)組:

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

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

          不過(guò)有一點(diǎn)需要說(shuō)明的是,在IE6,7,8下,返回的數(shù)組同時(shí)包含lastIndex信息,用來(lái)表示表示匹配子串的下一個(gè)位置。話(huà)說(shuō)這個(gè)屬性應(yīng)該是在regexp上面的,所以在IE9里面去掉了。

          String.exec()方法:

          <!–[if !supportLists]–>1、 <!–[endif]–>如果 regexp 不具有標(biāo)志 g。

          匹配情況

          返回值

          沒(méi)有找到任何匹配的子串

          null

          找到了一個(gè)或多個(gè)匹配子串

          一個(gè)數(shù)組。數(shù)組的內(nèi)容與調(diào)用match() 返回的數(shù)組是相同的。

          沿用上面的例子:

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

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

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

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

          贊(0)
          分享到: 更多 (0)
          網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)