久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

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

      主要參考W3C教程

      String.match()

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

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

      匹配情況

      返回值

      沒有找到任何匹配的子串

      null

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

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

      下面是個實例:

      復制代碼 代碼如下:
      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 沒有標志 g,那么 match() 方法就只能目標字符串中執(zhí)行一次匹配。

      匹配情況

      返回值

      沒有找到任何匹配的子串

      null

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

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

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

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

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

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

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

      String.exec()方法:

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

      匹配情況

      返回值

      沒有找到任何匹配的子串

      null

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

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

      沿用上面的例子:

      復制代碼 代碼如下:
      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ù)組同時包含lastIndex信息。
      <!–[if !supportLists]–>2、 <!–[endif]–>如果 regexp 具有標志 g。
      它會在 regexp的 lastIndex 屬性指定的字符處開始檢索。當 exec() 找到了與表達式相匹配的文本時,在匹配后,它將把 regexp的 lastIndex 屬性設置為匹配文本的最后一個字符的下一個位置。這就是說,可以通過反復調(diào)用 exec() 方法來遍歷字符串中的所有匹配文本。當 exec() 再也找不到匹配的文本時,它將返回 null,并把 lastIndex 屬性重置為 0。
      注:無論 RegExpObject 是否是全局模式,exec() 都會把完整的細節(jié)添加到它返回的數(shù)組中。這就是 exec() 與 match() 的不同之處,后者在全局模式下返回的信息要少得多。如果要獲得所有的匹配細節(jié),就可以在全局模式下循環(huán)調(diào)用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上面,而不是返回的數(shù)組結(jié)果里面,IE6,7,8在match()方法的lastIndex實現(xiàn)上有bug。
      <!–[if !supportLists]–>(2) <!–[endif]–>如果在一個字符串中完成了一次模式匹配之后要開始檢索新的字符串,就必須手動地把 lastIndex 屬性重置為 0。

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