久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放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. 站長資訊網
      最全最豐富的資訊網站

      JavaScript RegExp 正則表達式對象詳細說明

      直接量語法

      /pattern/attributes

      創(chuàng)建 RegExp 對象的語法:

      復制代碼 代碼如下:
      var obj=new RegExp(pattern,attributes);

      事例1:

      復制代碼 代碼如下:
      var pattern=/a/;
      document.write(pattern.exec(“asdas”));

      事例2:

      復制代碼 代碼如下:
      var obj=new RegExp(“a”);
      document.write(obj.exec(“asdas”));

      事例1和事例2的執(zhí)行結果是相同的;
      參數
      參數 pattern 是一個字符串,指定了正則表達式的模式或其他正則表達式。

      參數 attributes 是一個可選的字符串,包含屬性 “g”(執(zhí)行全局匹配查找所有匹配而非在找到第一個匹配后停止。)、”i”:執(zhí)行對大小寫不敏感的匹配。 和 “m”:執(zhí)行多行匹配。,分別用于指定全局匹配、區(qū)分大小寫的匹配和多行匹配。ECMAScript 標準化之前,不支持 m 屬性。如果 pattern 是正則表達式,而不是字符串,則必須省略該參數。

      返回值
      一個新的 RegExp 對象,具有指定的模式和標志。如果參數 pattern 是正則表達式而不是字符串,那么 RegExp() 構造函數將用與指定的 RegExp 相同的模式和標志創(chuàng)建一個新的 RegExp 對象。

      如果不用 new 運算符,而將 RegExp() 作為函數調用,那么它的行為與用 new 運算符調用時一樣,只是當pattern 是正則表達式時,它只返回 pattern,而不再創(chuàng)建一個新的 RegExp 對象。

      拋出
      SyntaxError – 如果 pattern 不是合法的正則表達式,或 attributes 含有 “g”、”i” 和 “m” 之外的字符,拋出該異常。

      TypeError – 如果 pattern 是 RegExp 對象,但沒有省略 attributes 參數,拋出該異常。
      RegExp 對象方法:
      1、test():檢索字符串中指定的值。返回 true 或 false。

      復制代碼 代碼如下:
      var patt1=new RegExp(“e”);
      document.write(patt1.test(“The best things in life are free”));

      2、exec():檢索字符串中指定的值。返回找到的值,并確定其位置。

      復制代碼 代碼如下:
      方法檢索字符串中的指定值。返回值是被找到的值。如果沒有發(fā)現匹配,則返回 null。

      3、compile():既可以改變檢索模式,也可以添加或刪除第二個參數。

      復制代碼 代碼如下:
      var patt1=new RegExp(“e”);
      document.write(patt1.test(“The best things in life are free”));
      patt1.compile(“d”);
      document.write(patt1.test(“The best things in life are free”));

      修飾符:

      1、g:執(zhí)行全局匹配查找所有匹配而非在找到第一個匹配后停止;
      在使用 “g” 參數時,exec() 的工作原理如下:
      找到第一個 “e”,并存儲其位置
      如果再次運行 exec(),則從存儲的位置開始檢索,并找到下一個 “e”,并存儲其位置

      復制代碼 代碼如下:
      var patt1=new RegExp(“e”,”g”);
      do
      {
      result=patt1.exec(“The best things in life are free”);
      document.write(result);
      }
      while (result!=null)

      RegExp 對象屬性
      1:global:RegExp 對象是否具有標志 g。
      2:ignoreCase:RegExp 對象是否具有標志 i。
      3:lastIndex:一個整數,標示開始下一次匹配的字符起始位置。
      4:multiline:RegExp 對象是否具有標志 m;
      5:source:正則表達式的源文本。

      復制代碼 代碼如下:
      var obj=new RegExp(/s/);
      document.write(obj.source);

      支持正則表達式的 String 對象的方法
      1:search() 方法用于檢索字符串中指定的子字符串,或檢索與正則表達式相匹配的子字符串。
      忽略大小寫事例:

      復制代碼 代碼如下:
      <script type=”text/javascript”>
      var str=”Visit W3School!”
      document.write(str.search(/w3school/i))
      </script>

      返回值

      stringObject 中第一個與 regexp 相匹配的子串的起始位置。

      注釋:如果沒有找到任何匹配的子串,則返回 -1。

      說明

      search() 方法不執(zhí)行全局匹配,它將忽略標志 g。它同時忽略 regexp 的 lastIndex 屬性,并且總是從字符串的開始進行檢索,這意味著它總是返回 stringObject 的第一個匹配的位置。

       

      2:match() 方法可在字符串內檢索指定的值,或找到一個或多個正則表達式的匹配。該方法類似 indexOf() 和 lastIndexOf(),但是它返回指定的值,而不是字符串的位置。

      返回值

      存放匹配結果的數組。該數組的內容依賴于 regexp 是否具有全局標志 g。

      說明

      match() 方法將檢索字符串 stringObject,以找到一個或多個與 regexp 匹配的文本。這個方法的行為在很大程度上有賴于 regexp 是否具有標志 g。

      如果 regexp 沒有標志 g,那么 match() 方法就只能在 stringObject 中執(zhí)行一次匹配。如果沒有找到任何匹配的文本, match() 將返回 null。否則,它將返回一個數組,其中存放了與它找到的匹配文本有關的信息。該數組的第 0 個元素存放的是匹配文本,而其余的元素存放的是與正則表達式的子表達式匹配的文本。除了這些常規(guī)的數組元素之外,返回的數組還含有兩個對象屬性。index 屬性聲明的是匹配文本的起始字符在 stringObject 中的位置,input 屬性聲明的是對 stringObject 的引用。

      如果 regexp 具有標志 g,則 match() 方法將執(zhí)行全局檢索,找到 stringObject 中的所有匹配子字符串。若沒有找到任何匹配的子串,則返回 null。如果找到了一個或多個匹配子串,則返回一個數組。不過全局匹配返回的數組的內容與前者大不相同,它的數組元素中存放的是 stringObject 中所有的匹配子串,而且也沒有 index 屬性或 input 屬性。

      注意:在全局檢索模式下,match() 即不提供與子表達式匹配的文本的信息,也不聲明每個匹配子串的位置。如果您需要這些全局檢索的信息,可以使用 RegExp.exec()。

      參數為字符串的事例:

      復制代碼 代碼如下:
      var str=”Hello world!”
      document.write(str.match(“world”) + “<br />”)

      參數為正則表達式的事例:

      復制代碼 代碼如下:
      var str=”1 plus 2 equal 3″
      document.write(str.match(/d+/g))

      3:replace() 方法用于在字符串中用一些字符替換另一些字符,或替換一個與正則表達式匹配的子串。

      stringObject.replace(regexp/substr,replacement)
      參數描述
      regexp/substr

      必需。規(guī)定子字符串或要替換的模式的 RegExp 對象。

      請注意,如果該值是一個字符串,則將它作為要檢索的直接量文本模式,而不是首先被轉換為 RegExp 對象。

      replacement必需。一個字符串值。規(guī)定了替換文本或生成替換文本的函數。

      返回值

      一個新的字符串,是用 replacement 替換了 regexp 的第一次匹配或所有匹配之后得到的。

      說明

      字符串 stringObject 的 replace() 方法執(zhí)行的是查找并替換的操作。它將在 stringObject 中查找與 regexp 相匹配的子字符串,然后用 replacement 來替換這些子串。如果 regexp 具有全局標志 g,那么 replace() 方法將替換所有匹配的子串。否則,它只替換第一個匹配子串。

      replacement 可以是字符串,也可以是函數。如果它是字符串,那么每個匹配都將由字符串替換。但是 replacement 中的 $ 字符具有特定的含義。如下表所示,它說明從模式匹配得到的字符串將用于替換。

      字符替換文本
      $1、$2、...、$99與 regexp 中的第 1 到第 99 個子表達式相匹配的文本。
      $&與 regexp 相匹配的子串。
      $`位于匹配子串左側的文本。
      $'位于匹配子串右側的文本。
      $$直接量符號。

      注意:ECMAScript v3 規(guī)定,replace() 方法的參數 replacement 可以是函數而不是字符串。在這種情況下,每個匹配都調用該函數,它返回的字符串將作為替換文本使用。該函數的第一個參數是匹配模式的字符串。接下來的參數是與模式中的子表達式匹配的字符串,可以有 0 個或多個這樣的參數。接下來的參數是一個整數,聲明了匹配在 stringObject 中出現的位置。最后一個參數是 stringObject 本身。

      字符串替換:
      復制代碼 代碼如下:

      var str="Visit Microsoft!"
      document.write(str.replace(/Microsoft/, "W3School"))

      全局替換:
      復制代碼 代碼如下:

      var str="Welcome to Microsoft! "
      str=str + "We are proud to announce that Microsoft has "
      str=str + "one of the largest Web Developers sites in the world."
      document.write(str.replace(/Microsoft/g, "W3School"))

      返回的結果:Welcome to W3School! We are proud to announce that W3Schoolhas one of the largest Web Developers sites in the world.使用正則表達式:
      復制代碼 代碼如下:

      name = '"a", "b"';
      name.replace(/"([^"]*)"/g, "'$1'");

      使用函數:
      復制代碼 代碼如下:

      name = 'aaa bbb ccc';
      uw=name.replace(/bw+b/g, function(word){
      return word.substring(0,1).toUpperCase()+word.substring(1);}
      );

      4:split() 方法用于把一個字符串分割成字符串數組。

      語法

      stringObject.split(separator,howmany)

      參數 描述
      separator 必需。字符串或正則表達式,從該參數指定的地方分割 stringObject。
      howmany 可選。該參數可指定返回的數組的最大長度。如果設置了該參數,返回的子串不會多于這個參數指定的數組。如果沒有設置該參數,整個字符串都會被分割,不考慮它的長度。

      返回值

      一個字符串數組。該數組是通過在 separator 指定的邊界處將字符串 stringObject 分割成子串創(chuàng)建的。返回的數組中的字串不包括 separator 自身。

      但是,如果 separator 是包含子表達式的正則表達式,那么返回的數組中包括與這些子表達式匹配的字串(但不包括與整個正則表達式匹配的文本)。

      提示和注釋

      注釋:如果把空字符串 ("") 用作 separator,那么 stringObject 中的每個字符之間都會被分割。

      注釋:String.split() 執(zhí)行的操作與 Array.join 執(zhí)行的操作是相反的。

      修飾符

      修飾符 描述
      i 執(zhí)行對大小寫不敏感的匹配。
      g 執(zhí)行全局匹配(查找所有匹配而非在找到第一個匹配后停止)。
      m 執(zhí)行多行匹配。

      方括號

      方括號用于查找某個范圍內的字符:

      表達式 描述
      [abc] 查找方括號之間的任何字符。
      [^abc] 查找任何不在方括號之間的字符。
      [0-9] 查找任何從 0 至 9 的數字。
      [a-z] 查找任何從小寫 a 到小寫 z 的字符。
      [A-Z] 查找任何從大寫 A 到大寫 Z 的字符。
      [a-Z] 查找任何從小寫 a 到大寫 Z 的字符。
      [adgk] 查找給定集合內的任何字符。
      [^adgk] 查找給定集合外的任何字符。
      [red|blue|green] 查找任何指定的選項。

      元字符

      元字符(Metacharacter)是擁有特殊含義的字符:

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

          元字符 描述
          . 查找單個字符,除了換行和行結束符。
          w 查找單詞字符。
          W 查找非單詞字符。
          d 查找數字。
          D 查找非數字字符。
          s 查找空白字符。
          S 查找非空白字符。
          b 查找位于單詞的開頭或結尾的匹配。
          B 查找不處在單詞的開頭或結尾的匹配。

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

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