JS的Regex

來源:互聯網
上載者:User

//校正是否全由數字組成
代碼
function isDigit(s)
{
var patrn=/^[0-9]{1,20}$/;
if (!patrn.exec(s)) return false
return true
}
//校正登入名稱:只能輸入5-20個以字母開頭、可帶數字、“_”、“.”的字串
代碼
function isRegisterUserName(s)
{
var patrn=/^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$/;
if (!patrn.exec(s)) return false
return true
}
//校正使用者姓名:只能輸入1-30個以字母開頭的字串
代碼
function isTrueName(s)
{
var patrn=/^[a-zA-Z]{1,30}$/;
if (!patrn.exec(s)) return false
return true
}
}}
//校正密碼:只能輸入6-20個字母、數字、底線
[code]
function isPasswd(s)
{
var patrn=/^(/w){6,20}$/;
if (!patrn.exec(s)) return false
return true
}
//校正普通電話、傳真號碼:可以“+”開頭,除數字外,可含有“-”
代碼
function isTel(s)
{
//var patrn=/^[+]{0,1}(/d){1,3}[ ]?([-]?(/d){1,12})+$/;
var patrn=/^[+]{0,1}(/d){1,3}[ ]?([-]?((/d)|[ ]){1,12})+$/;
if (!patrn.exec(s)) return false
return true
}
//校正手機號碼:必須以數字開頭,除數字外,可含有“-”
代碼
function isMobil(s)
{
var patrn=/^[+]{0,1}(/d){1,3}[ ]?([-]?((/d)|[ ]){1,12})+$/;
if (!patrn.exec(s)) return false
return true
}
//校正郵遞區號
代碼
function isPostalCode(s)
{
//var patrn=/^[a-zA-Z0-9]{3,12}$/;
var patrn=/^[a-zA-Z0-9 ]{3,12}$/;
if (!patrn.exec(s)) return false
return true
}
//校正搜尋索引鍵
代碼
function isSearch(s)
{
var patrn=/^[^`~!@#$%^&*()+=|///][/]/{/}:;'/,.<>/?]{1}[^`~!@$%^&()+=|///]
[/]/{/}:;'/,.<>?]{0,19}$/;
if (!patrn.exec(s)) return false
return true
}
function isIP(s) //by zergling
{
var patrn=/^[0-9.]{1,20}$/;
if (!patrn.exec(s)) return false
return true
}
Regex
代碼
"^//d+$"  //非負整數(正整數 + 0)
"^[0-9]*[1-9][0-9]*$"  //正整數
"^((-//d+)|(0+))$"  //非正整數(負整數 + 0)
"^-[0-9]*[1-9][0-9]*$"  //負整數
"^-?//d+$"    //整數
"^//d+(//.//d+)?$"  //非負浮點數(正浮點數 + 0)
"^(([0-9]+//.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*//.[0-9]+)|([0-9]*[1-9][0-9]*))$" 
//正浮點數
"^((-//d+(//.//d+)?)|(0+(//.0+)?))$"  //非正浮點數(負浮點數 + 0)
"^(-(([0-9]+//.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*//.[0-9]+)|([0-9]*[1-9][0-9]*)))$" 
//負浮點數
"^(-?//d+)(//.//d+)?$"  //浮點數
"^[A-Za-z]+$"  //由26個英文字母組成的字串
"^[A-Z]+$"  //由26個英文字母的大寫組成的字串
"^[a-z]+$"  //由26個英文字母的小寫組成的字串
"^[A-Za-z0-9]+$"  //由數字和26個英文字母組成的字串
"^//w+$"  //由數字、26個英文字母或者底線組成的字串
"^[//w-]+(//.[//w-]+)*@[//w-]+(//.[//w-]+)+$"    //email地址
"^[a-zA-z]+://(//w+(-//w+)*)(//.(//w+(-//w+)*))*(//?//S*)?$"  //url
"^[A-Za-z0-9_]*$"
Regex使用詳解
簡介
簡單的說,Regex是一種可以用於模式比對和替換的強有力的工具。其作用如下:
測試字串的某個模式。例如,可以對一個輸入字串進行測試,看在該字串是否存在一個電話號碼模式或一個信用卡號碼模式。這稱為資料有效性驗證。
替換文本。可以在文檔中使用一個Regex來標識特定文字,然後可以全部將其刪除,或者替換為別的文字。
根據模式比對從字串中提取一個子字串。可以用來在文本或輸入欄位中尋找特定文字。
基本文法
在對Regex的功能和作用有了初步的瞭解之後,我們就來具體看一下Regex的文法格式。

Regex的形式一般如下:  
/love/  其中位於“/”定界符之間的部分就是將要在目標對象中進行匹配的模式。使用者只要把希望尋找匹配對象的模式內容放入“/”定界符之間即可。為了能夠使使用者更加靈活的定製模式內容,Regex提供了專門的“元字元”。所謂元字元就是指那些在Regex中具有特殊意義的專用字元,可以用來規定其前置字元(即位於元字元前面的字元)在目標對象中的出現模式。
較為常用的元字元包括: “+”, “*”,以及 “?”。
“+”元字元規定其前置字元必須在目標對象中連續出現一次或多次。
“*”元字元規定其前置字元必須在目標對象中出現零次或連續多次。
“?”元字元規定其前置對象必須在目標對象中連續出現零次或一次。
下面,就讓我們來看一下Regex元字元的具體應用。
/fo+/  因為上述Regex中包含“+”元字元,表示可以與目標對象中的 “fool”, “fo”, 或者 “football”等在字母f後面連續出現一個或多個字母o的字串相匹配。
/eg*/  因為上述Regex中包含“*”元字元,表示可以與目標對象中的 “easy”, “ego”, 或者 “egg”等在字母e後面連續出現零個或多個字母g的字串相匹配。
/Wil?/  因為上述Regex中包含“?”元字元,表示可以與目標對象中的 “Win”, 或者“Wilson”,等在字母i後面連續出現零個或一個字母l的字串相匹配。
有時候不知道要匹配多少字元。為了能適應這種不確定性,Regex支援限定符的概念。這些限定符可以指定Regex的一個給定組件必須要出現多少次才能滿足匹配。
{n} n 是一個非負整數。匹配確定的 n 次。例如,'o{2}' 不能匹配 "Bob" 中的 'o',但是能匹配 "food" 中的兩個 o。
{n,} n 是一個非負整數。至少匹配 n 次。例如,'o{2,}' 不能匹配 "Bob" 中的 'o',但能匹配 "foooood" 中的所有 o。'o{1,}' 等價於 'o+'。'o{0,}' 則等價於 'o*'。
{n,m} m 和 n 均為非負整數,其中n <= m。最少匹配 n 次且最多匹配 m 次。例如,"o{1,3}" 將匹配 "fooooood" 中的前三個 o。'o{0,1}' 等價於 'o?'。請注意在逗號和兩個數之間不能有空格。
除了元字元之外,使用者還可以精確指定模式在匹配對象中出現的頻率。例如,/jim {2,6}/ 上述Regex規定字元m可以在匹配對象中連續出現2-6次,因此,上述Regex可以同jimmy或jimmmmmy等字串相匹配。
在對如何使用Regex有了初步瞭解之後,我們來看一下其它幾個重要的元字元的使用方式。
代碼
/s:用於匹配單個空格符,包括tab鍵和分行符號;
/S:用於匹配除單個空格符之外的所有字元;
/d:用於匹配從0到9的數字;
/w:用於匹配字母,數字或底線;
/W:用於匹配所有與/w不匹配的字元;
. :用於匹配除分行符號之外的所有字元。

(說明:我們可以把/s和/S以及/w和/W看作互為逆運算)
下面,我們就通過執行個體看一下如何在Regex中使用上述元字元。
//s+/ 上述Regex可以用於匹配目標對象中的一個或多個空白字元。
//d000/ 如果我們手中有一份複雜的財務報表,那麼我們可以通過上述Regex輕而易舉尋找到所有總額達千元的款項。
除了我們以上所介紹的元字元之外,Regex中還具有另外一種較為獨特的專用字元,即定位器。定位器用於規定匹配模式在目標對象中的出現位置。 較為常用的定位器包括: “^”, “$”, “/b” 以及 “/B”。
代碼
“^”定位器規定匹配模式必須出現在目標字串的開頭
“$”定位器規定匹配模式必須出現在目標對象的結尾
“/b”定位器規定匹配模式必須出現在目標字串的開頭或結尾的兩個邊界之一
“/B”定位器則規定匹配對象必須位於目標字串的開頭和結尾兩個邊界之內,
即匹配對象既不能作為目標字串的開頭,也不能作為目標字串的結尾。

同樣,我們也可以把“^”和“$”以及“/b”和“/B”看作是互為逆運算的兩組定位器。舉例來說: /^hell/ 因為上述Regex中包含“^”定位器,所以可以與目標對象中以 “hell”, “hello”或“hellhound”開頭的字串相匹配。 /ar$/ 因為上述Regex中包含“$”定位器,所以可以與目標對象中以 “car”, “bar”或 “ar” 結尾的字串相匹配。 //bbom/ 因為上述Regex模式以“/b”定位器開頭,所以可以與目標對象中以 “bomb”, 或 “bom”開頭的字串相匹配。/man/b/ 因為上述Regex模式以“/b”定位器結尾,所以可以與目標對象中以 “human”, “woman”或 “man”結尾的字串相匹配。
為了能夠方便使用者更加靈活的設定匹配模式,Regex允許使用者在匹配模式中指定某一個範圍而不局限於具體的字元。例如:
代碼
/[A-Z]/  上述Regex將會與從A到Z範圍內任何一個大寫字母相匹配。
/[a-z]/  上述Regex將會與從a到z範圍內任何一個小寫字母相匹配。
/[0-9]/  上述Regex將會與從0到9範圍內任何一個數字相匹配。
/([a-z][A-Z][0-9])+/ 上述Regex將會與任何由字母和數字組成的字串,如 “aB0” 等相匹配。

這裡需要提醒使用者注意的一點就是可以在Regex中使用 “()” 把字串組合在一起。“()”符號包含的內容必須同時出現在目標對象中。因此,上述Regex將無法與諸如 “abc”等的字串匹配,因為“abc”中的最後一個字元為字母而非數字。
如果我們希望在Regex中實作類別似編程邏輯中的“或”運算,在多個不同的模式中任選一個進行匹配的話,可以使用管道符 “|”。例如:/to|too|2/ 上述Regex將會與目標對象中的 “to”, “too”, 或 “2” 相匹配。
Regex中還有一個較為常用的運算子,即否定符 “[^]”。與我們前文所介紹的定位器 “^” 不同,否定符 “[^]”規定目標對象中不能存在模式中所規定的字串。例如:/[^A-C]/ 上述字串將會與目標對象中除A,B,和C之外的任何字元相匹配。一般來說,當“^”出現在 “[]”內時就被視做否定運算子;而當“^”位於“[]”之外,或沒有“[]”時,則應當被視做定位器。
最後,當使用者需要在Regex的模式中加入元字元,並尋找其匹配對象時,可以使用轉義符“/”。例如:/Th/*/  上述Regex將會與目標對象中的“Th*”而非“The”等相匹配。
在構造Regex之後,就可以象數學運算式一樣來求值,也就是說,可以從左至右並按照一個優先順序順序來求值。優先順序如下:
代碼
1./ 轉義符
2.(), (?:), (?=), [] 圓括弧和方括弧
3.*, +, ?, {n}, {n,}, {n,m} 限定符
4.^, $, /anymetacharacter 位置和順序
5.|“或”操作
使用執行個體
在JavaScript 1.2中帶有一個功能強大的RegExp()對象,可以用來進行Regex的匹配操作。其中的test()方法可以檢驗目標對象中是否包含匹配模式,並相應的返回true或false。
我們可以使用JavaScript編寫以下指令碼,驗證使用者輸入的郵件地址的有效性。
代碼
<html>
<head>
  <script language="Javascript1.2">
     <!-- start hiding
     function verifyAddress(obj)
     {
      var email = obj.email.value;
      var pattern =
/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(/.[a-zA-Z0-9_-])+/;
      flag = pattern.test(email);
      if(flag)
      {
       alert(“Your email address is correct!”);
       return true;
      }
      else
       {
        alert(“Please try again!”);
        return false;
        }
      }
     // stop hiding -->
    </script>
  </head>
  <body>
   <form onSubmit="return verifyAddress(this);">
    <input name="email" type="text">
    <input type="submit">
    </form>
  </body>
</html>

作者 Heng_Ji

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.