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

        js 常用正則表達式表單驗證代碼

        正則表達式使用詳解

        簡介

        簡單的說,正則表達式是一種可以用于模式匹配和替換的強有力的工具。其作用如下:
        測試字符串的某個模式。例如,可以對一個輸入字符串進行測試,看在該字符串是否存在一個電話號碼模式或一個信用卡號碼模式。這稱為數據有效性驗證。
        替換文本。可以在文檔中使用一個正則表達式來標識特定文字,然后可以全部將其刪除,或者替換為別的文字。
        根據模式匹配從字符串中提取一個子字符串??梢杂脕碓谖谋净蜉斎胱侄沃胁檎姨囟ㄎ淖帧?/p>

        基本語法

        在對正則表達式的功能和作用有了初步的了解之后,我們就來具體看一下正則表達式的語法格式。

        正則表達式的形式一般如下:

        /love/其中位于“/”定界符之間的部分就是將要在目標對象中進行匹配的模式。用戶只要把希望查找匹配對象的模式內容放入“/”定界符之間即可。為了能夠使用戶更加靈活的定制模式內容,正則表達式提供了專門的“元字符”。所謂元字符就是指那些在正則表達式中具有特殊意義的專用字符,可以用來規定其前導字符(即位于元字符前面的字符)在目標對象中的出現模式。
        較為常用的元字符包括: “+”, “*”,以及 “?”。
        “+”元字符規定其前導字符必須在目標對象中連續出現一次或多次。
        “*”元字符規定其前導字符必須在目標對象中出現零次或連續多次。
        “?”元字符規定其前導對象必須在目標對象中連續出現零次或一次。

        下面,就讓我們來看一下正則表達式元字符的具體應用。

        /fo+/因為上述正則表達式中包含“+”元字符,表示可以與目標對象中的 “fool”, “fo”, 或者 “football”等在字母f后面連續出現一個或多個字母o的字符串相匹配。
        /eg*/因為上述正則表達式中包含“*”元字符,表示可以與目標對象中的 “easy”, “ego”, 或者 “egg”等在字母e后面連續出現零個或多個字母g的字符串相匹配。
        /Wil?/因為上述正則表達式中包含“?”元字符,表示可以與目標對象中的 “Win”, 或者“Wilson”,等在字母i后面連續出現零個或一個字母l的字符串相匹配。

        有時候不知道要匹配多少字符。為了能適應這種不確定性,正則表達式支持限定符的概念。這些限定符可以指定正則表達式的一個給定組件必須要出現多少次才能滿足匹配。

        {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}/ 上述正則表達式規定字符m可以在匹配對象中連續出現2-6次,因此,上述正則表達式可以同jimmy或jimmmmmy等字符串相匹配。

        在對如何使用正則表達式有了初步了解之后,我們來看一下其它幾個重要的元字符的使用方式。
        s:用于匹配單個空格符,包括tab鍵和換行符;
        S:用于匹配除單個空格符之外的所有字符;
        d:用于匹配從0到9的數字;
        w:用于匹配字母,數字或下劃線字符;
        W:用于匹配所有與w不匹配的字符;
        . :用于匹配除換行符之外的所有字符。

        (說明:我們可以把s和S以及w和W看作互為逆運算)

        下面,我們就通過實例看一下如何在正則表達式中使用上述元字符。

        /s+/ 上述正則表達式可以用于匹配目標對象中的一個或多個空格字符。
        /d000/ 如果我們手中有一份復雜的財務報表,那么我們可以通過上述正則表達式輕而易舉的查找到所有總額達千元的款項。
        除了我們以上所介紹的元字符之外,正則表達式中還具有另外一種較為獨特的專用字符,即定位符。定位符用于規定匹配模式在目標對象中的出現位置。 較為常用的定位符包括: “^”, “$”, “b” 以及 “B”。
        “^”定位符規定匹配模式必須出現在目標字符串的開頭
        “$”定位符規定匹配模式必須出現在目標對象的結尾
        “b”定位符規定匹配模式必須出現在目標字符串的開頭或結尾的兩個邊界之一
        “B”定位符則規定匹配對象必須位于目標字符串的開頭和結尾兩個邊界之內,
        即匹配對象既不能作為目標字符串的開頭,也不能作為目標字符串的結尾。
        同樣,我們也可以把“^”和“$”以及“b”和“B”看作是互為逆運算的兩組定位符。舉例來說: /^hell/ 因為上述正則表達式中包含“^”定位符,所以可以與目標對象中以 “hell”, “hello”或“hellhound”開頭的字符串相匹配。 /ar$/ 因為上述正則表達式中包含“$”定位符,所以可以與目標對象中以 “car”, “bar”或 “ar” 結尾的字符串相匹配。 /bbom/ 因為上述正則表達式模式以“b”定位符開頭,所以可以與目標對象中以 “bomb”, 或 “bom”開頭的字符串相匹配。/manb/ 因為上述正則表達式模式以“b”定位符結尾,所以可以與目標對象中以 “human”, “woman”或 “man”結尾的字符串相匹配。
        為了能夠方便用戶更加靈活的設定匹配模式,正則表達式允許使用者在匹配模式中指定某一個范圍而不局限于具體的字符。例如:
        /[A-Z]/上述正則表達式將會與從A到Z范圍內任何一個大寫字母相匹配。
        /[a-z]/上述正則表達式將會與從a到z范圍內任何一個小寫字母相匹配。
        /[0-9]/  上述正則表達式將會與從0到9范圍內任何一個數字相匹配。
        /([a-z][A-Z][0-9])+/ 上述正則表達式將會與任何由字母和數字組成的字符串,如 “aB0” 等相匹配。

        這里需要提醒用戶注意的一點就是可以在正則表達式中使用 “()” 把字符串組合在一起?!?)”符號包含的內容必須同時出現在目標對象中。因此,上述正則表達式將無法與諸如 “abc”等的字符串匹配,因為“abc”中的最后一個字符為字母而非數字。
        如果我們希望在正則表達式中實現類似編程邏輯中的“或”運算,在多個不同的模式中任選一個進行匹配的話,可以使用管道符 “|”。例如:/to|too|2/ 上述正則表達式將會與目標對象中的 “to”, “too”, 或 “2” 相匹配。
        正則表達式中還有一個較為常用的運算符,即否定符 “[^]”。與我們前文所介紹的定位符 “^” 不同,否定符 “[^]”規定目標對象中不能存在模式中所規定的字符串。例如:/[^A-C]/ 上述字符串將會與目標對象中除A,B,和C之外的任何字符相匹配。一般來說,當“^”出現在 “[]”內時就被視做否定運算符;而當“^”位于“[]”之外,或沒有“[]”時,則應當被視做定位符。
        最后,當用戶需要在正則表達式的模式中加入元字符,并查找其匹配對象時,可以使用轉義符“”。例如:/Th*/  上述正則表達式將會與目標對象中的“Th*”而非“The”等相匹配。

        在構造正則表達式之后,就可以象數學表達式一樣來求值,也就是說,可以從左至右并按照一個優先級順序來求值。優先級如下:

        1. 轉義符
        2.(), (?:), (?=), [] 圓括號和方括號
        3.*, +, ?, {n}, {n,}, {n,m} 限定符
        4.^, $, anymetacharacter 位置和順序
        5.|“或”操作

        使用實例

        在JavaScript 1.2中帶有一個功能強大的RegExp()對象,可以用來進行正則表達式的匹配操作。其中的test()方法可以檢驗目標對象中是否包含匹配模式,并相應的返回true或false。
        我們可以使用JavaScript編寫以下腳本,驗證用戶輸入的郵件地址的有效性。
        正則表達式對象
          本對象包含正則表達式模式以及表明如何應用模式的標志。
          語法 1 re = /pattern/[flags]
          語法 2 re = new RegExp(“pattern”,[“flags”])
          參數
          re
          必選項。將要賦值為正則表達式模式的變量名。
          Pattern
          必選項。要使用的正則表達式模式。如果使用語法 1,用 “/” 字符分隔模式。如果用語法 2,用引號將模式引起來。
          Flags
          可選項。如果使用語法 2 要用引號將 flag 引起來。標志可以組合使用,可用的有:
          g (全文查找出現的所有 pattern)
          i (忽略大小寫)
          m (多行查找)

          示例

          下面的示例創建一個包含正則表達式模式及相關標志的對象(re),向您演示正則表達式對象的用法。在本例中,作為結果的正則表達式對象又用于 match 方法中:

        復制代碼 代碼如下:
        function MatchDemo()
          {
          var r, re; // 聲明變量。
          var s = “The rain in Spain falls mainly in the plain”;
          re = new RegExp(“ain”,”g”); // 創建正則表達式對象。
          r = s.match(re); // 在字符串 s 中查找匹配。
          return(r);
          }

        下面是具體的使用:

        方法一:
        var re=/正則表達式/;
        re.test($(“txtid”).val())

        方法二:
        $(“txtid”).val.match(/正則表達式/);

        正則表達式有多種不同的風格。下表是在PCRE中元字符及其在正則表達式上下文中的行為的一個完整列表:

        字符 描述
        將下一個字符標記為一個特殊字符、或一個原義字符、或一個向后引用、或一個八進制轉義符。例如,“n”匹配字符“n”。“n”匹配一個換行符。序列“\”匹配“”而“(”則匹配“(”。
        ^ 匹配輸入字符串的開始位置。如果設置了RegExp對象的Multiline屬性,^也匹配“n”或“r”之后的位置。
        $ 匹配輸入字符串的結束位置。如果設置了RegExp對象的Multiline屬性,$也匹配“n”或“r”之前的位置。
        * 匹配前面的子表達式零次或多次。例如,zo*能匹配“z”以及“zoo”。*等價于{0,}。
        + 匹配前面的子表達式一次或多次。例如,“zo+”能匹配“zo”以及“zoo”,但不能匹配“z”。+等價于{1,}。
        ? 匹配前面的子表達式零次或一次。例如,“do(es)?”可以匹配“do”或“does”中的“do”。?等價于{0,1}。
        {n} n是一個非負整數。匹配確定的n次。例如,“o{2}”不能匹配“Bob”中的“o”,但是能匹配“food”中的兩個o。
        {n,} n是一個非負整數。至少匹配n次。例如,“o{2,}”不能匹配“Bob”中的“o”,但能匹配“foooood”中的所有o?!皁{1,}”等價于“o+”。“o{0,}”則等價于“o*”。
        {n,m} m和n均為非負整數,其中n<=m。最少匹配n次且最多匹配m次。例如,“o{1,3}”將匹配“fooooood”中的前三個o。“o{0,1}”等價于“o?”。請注意在逗號和兩個數之間不能有空格。
        ? 當該字符緊跟在任何一個其他限制符(*,+,?,{n},{n,},{n,m})后面時,匹配模式是非貪婪的。非貪婪模式盡可能少的匹配所搜索的字符串,而默認的貪婪模式則盡可能多的匹配所搜索的字符串。例如,對于字符串“oooo”,“o+?”將匹配單個“o”,而“o+”將匹配所有“o”。
        . 匹配除“n”之外的任何單個字符。要匹配包括“n”在內的任何字符,請使用像“[.n]”的模式。
        (pattern) 匹配pattern并獲取這一匹配。所獲取的匹配可以從產生的Matches集合得到,在VBScript中使用SubMatches集合,在JScript中則使用$0…$9屬性。要匹配圓括號字符,請使用“(”或“)”。
        (?:pattern) 匹配pattern但不獲取匹配結果,也就是說這是一個非獲取匹配,不進行存儲供以后使用。這在使用或字符“(|)”來組合一個模式的各個部分是很有用。例如“industr(?:y|ies)”就是一個比“industry|industries”更簡略的表達式。
        (?=pattern) 正向預查,在任何匹配pattern的字符串開始處匹配查找字符串。這是一個非獲取匹配,也就是說,該匹配不需要獲取供以后使用。例如,“Windows(?=95|98|NT|2000)”能匹配“Windows2000”中的“Windows”,但不能匹配“Windows3.1”中的“Windows”。預查不消耗字符,也就是說,在一個匹配發生后,在最后一次匹配之后立即開始下一次匹配的搜索,而不是從包含預查的字符之后開始。
        (?!pattern) 負向預查,在任何不匹配pattern的字符串開始處匹配查找字符串。這是一個非獲取匹配,也就是說,該匹配不需要獲取供以后使用。例如“Windows(?!95|98|NT|2000)”能匹配“Windows3.1”中的“Windows”,但不能匹配“Windows2000”中的“Windows”。預查不消耗字符,也就是說,在一個匹配發生后,在最后一次匹配之后立即開始下一次匹配的搜索,而不是從包含預查的字符之后開始
        x|y 匹配x或y。例如,“z|food”能匹配“z”或“food”?!?z|f)ood”則匹配“zood”或“food”。
        [xyz] 字符集合。匹配所包含的任意一個字符。例如,“[abc]”可以匹配“plain”中的“a”。
        [^xyz] 負值字符集合。匹配未包含的任意字符。例如,“[^abc]”可以匹配“plain”中的“p”。
        [a-z] 字符范圍。匹配指定范圍內的任意字符。例如,“[a-z]”可以匹配“a”到“z”范圍內的任意小寫字母字符。
        [^a-z] 負值字符范圍。匹配任何不在指定范圍內的任意字符。例如,“[^a-z]”可以匹配任何不在“a”到“z”范圍內的任意字符。
        b 匹配一個單詞邊界,也就是指單詞和空格間的位置。例如,“erb”可以匹配“never”中的“er”,但不能匹配“verb”中的“er”。
        B 匹配非單詞邊界?!癳rB”能匹配“verb”中的“er”,但不能匹配“never”中的“er”。
        cx 匹配由x指明的控制字符。例如,cM匹配一個Control-M或回車符。x的值必須為A-Z或a-z之一。否則,將c視為一個原義的“c”字符。
        d 匹配一個數字字符。等價于[0-9]。
        D 匹配一個非數字字符。等價于[^0-9]。
        f 匹配一個換頁符。等價于x0c和cL。
        n 匹配一個換行符。等價于x0a和cJ。
        r 匹配一個回車符。等價于x0d和cM。
        s 匹配任何空白字符,包括空格、制表符、換頁符等等。等價于[fnrtv]。
        S 匹配任何非空白字符。等價于[^fnrtv]。
        t 匹配一個制表符。等價于x09和cI。
        v 匹配一個垂直制表符。等價于x0b和cK。
        w 匹配包括下劃線的任何單詞字符。等價于“[A-Za-z0-9_]”。
        W 匹配任何非單詞字符。等價于“[^A-Za-z0-9_]”。
        xn 匹配n,其中n為十六進制轉義值。十六進制轉義值必須為確定的兩個數字長。例如,“x41”匹配“A”?!皒041”則等價于“x04&1”。正則表達式中可以使用ASCII編碼。.
        num 匹配num,其中num是一個正整數。對所獲取的匹配的引用。例如,“(.)1”匹配兩個連續的相同字符。
        n 標識一個八進制轉義值或一個向后引用。如果n之前至少n個獲取的子表達式,則n為向后引用。否則,如果n為八進制數字(0-7),則n為一個八進制轉義值。
        nm 標識一個八進制轉義值或一個向后引用。如果nm之前至少有nm個獲得子表達式,則nm為向后引用。如果nm之前至少有n個獲取,則n為一個后跟文字m的向后引用。如果前面的條件都不滿足,若n和m均為八進制數字(0-7),則nm將匹配八進制轉義值nm。
        nml 如果n為八進制數字(0-3),且m和l均為八進制數字(0-7),則匹配八進制轉義值nml。
        un 匹配n,其中n是一個用四個十六進制數字表示的Unicode字符。例如,u00A9匹配版權符號(?)。

        附:

        驗證數字的正則表達式集(轉載)
        驗證數字:^[0-9]*$
        驗證n位的數字:^d{n}$
        驗證至少n位數字:^d{n,}$
        驗證m-n位的數字:^d{m,n}$
        驗證零和非零開頭的數字:^(0|[1-9][0-9]*)$
        驗證有兩位小數的正實數:^[0-9]+(.[0-9]{2})?$
        驗證有1-3位小數的正實數:^[0-9]+(.[0-9]{1,3})?$
        驗證非零的正整數:^+?[1-9][0-9]*$
        驗證非零的負整數:^-[1-9][0-9]*$
        驗證非負整數(正整數 + 0) ^d+$
        驗證非正整數(負整數 + 0) ^((-d+)|(0+))$
        驗證長度為3的字符:^.{3}$
        驗證由26個英文字母組成的字符串:^[A-Za-z]+$
        驗證由26個大寫英文字母組成的字符串:^[A-Z]+$
        驗證由26個小寫英文字母組成的字符串:^[a-z]+$
        驗證由數字和26個英文字母組成的字符串:^[A-Za-z0-9]+$
        驗證由數字、26個英文字母或者下劃線組成的字符串:^w+$
        驗證用戶密碼:^[a-zA-Z]w{5,17}$ 正確格式為:以字母開頭,長度在6-18之間,只能包含字符、數字和下劃線。
        驗證是否含有 ^%&’,;=?$” 等字符:[^%&’,;=?$x22]+
        驗證漢字:^[u4e00-u9fa5],{0,}$
        驗證Email地址:^w+[-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$
        驗證InternetURL:^http://([w-]+.)+[w-]+(/[w-./?%&=]*)?$ ;^[a-zA-z]+://(w+(-w+)*)(.(w+(-w+)*))*(?S*)?$
        驗證電話號碼:^((d{3,4})|d{3,4}-)?d{7,8}$:–正確格式為:XXXX-XXXXXXX,XXXX-XXXXXXXX,XXX-XXXXXXX,XXX-XXXXXXXX,XXXXXXX,XXXXXXXX。
        驗證身份證號(15位或18位數字):^d{15}|d{}18$
        驗證一年的12個月:^(0?[1-9]|1[0-2])$ 正確格式為:“01”-“09”和“1”“12”
        驗證一個月的31天:^((0?[1-9])|((1|2)[0-9])|30|31)$ 正確格式為:01、09和1、31。
        整數:^-?d+$
        非負浮點數(正浮點數 + 0):^d+(.d+)?$
        正浮點數 ^(([0-9]+.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*.[0-9]+)|([0-9]*[1-9][0-9]*))$
        非正浮點數(負浮點數 + 0) ^((-d+(.d+)?)|(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+)?

        下面是具體的函數寫法,不會的可以參考下。

        復制代碼 代碼如下:
        function check()
        {
        var bb = document.getElementById(“txt_id”).value;//txt_id為文本框的ID
        alert(ismobile(bb));//ismobile 代表以下任何一個函數名稱
        }
        HTML代碼:
        <input type=”text” name=”textfield” id=”txt_id” />
        <input type=”submit” name=”Submit” value=”提交” onclick=”check()” />
        **************************/
        // 判斷輸入是否是一個由 0-9 / A-Z / a-z 組成的字符串
        function isalphanumber(str)
        {
        var result=str.match(/^[a-zA-Z0-9]+$/);
        if(result==null) return false;
        return true;
        }

        // 判斷輸入是否是一個數字–(數字包含小數)–
        function isnumber(str)
        {
        return !isNaN(str);
        }

        // 判斷輸入是否是一個整數
        function isint(str)
        {
        var result=str.match(/^(-|+)?d+$/);
        if(result==null) return false;
        return true;
        }

        // 判斷輸入是否是有效的長日期格式 – “YYYY-MM-DD HH:MM:SS” || “YYYY/MM/DD HH:MM:SS”
        function isdatetime(str)
        {
        var result=str.match(/^(d{4})(-|/)(d{1,2})2(d{1,2}) (d{1,2}):(d{1,2}):(d{1,2})$/);
        if(result==null) return false;
        var d= new Date(result[1], result[3]-1, result[4], result[5], result[6], result[7]);
        return (d.getFullYear()==result[1]&&(d.getMonth()+1)==result[3]&&d.getDate()==result[4]&&d.getHours()==result[5]&&d.getMinutes()==result[6]&&d.getSeconds()==result[7]);
        }

        // 檢查是否為 YYYY-MM-DD || YYYY/MM/DD 的日期格式
        function isdate(str){
        var result=str.match(/^(d{4})(-|/)(d{1,2})2(d{1,2})$/);
        if(result==null) return false;
        var d=new Date(result[1], result[3]-1, result[4]);
        return (d.getFullYear()==result[1] && d.getMonth()+1==result[3] && d.getDate()==result[4]);
        }

        // 判斷輸入是否是有效的電子郵件
        function isemail(str)
        {
        var result=str.match(/^w+((-w+)|(.w+))*@[A-Za-z0-9]+((.|-)[A-Za-z0-9]+)*.[A-Za-z0-9]+$/);
        if(result==null) return false;
        return true;
        }

        // 去除字符串的首尾的空格
        function trim(str){
        return str.replace(/(^s*)|(s*$)/g, “”);
        }

        // 返回字符串的實際長度, 一個漢字算2個長度
        function strlen(str){
        return str.replace(/[^x00-xff]/g, “**”).length;
        }

        //匹配中國郵政編碼(6位)
        function ispostcode(str)
        {
        var result=str.match(/[1-9]d{5}(?!d)/);
        if(result==null) return false;
        return true;
        }
        //匹配國內電話號碼(0511-4405222 或 021-87888822)
        function istell(str)
        {
        var result=str.match(/d{3}-d{8}|d{4}-d{7}/);
        if(result==null) return false;
        return true;
        }

        //校驗是否為(0-10000)的整數
        function isint1(str)
        {
        var result=str.match(/^[0-9]$|^([1-9])([0-9]){0,3}$|^10000$/);
        if(result==null) return false;
        return true;
        }

        //匹配騰訊QQ號
        function isqq(str)
        {
        var result=str.match(/[1-9][0-9]{4,}/);
        if(result==null) return false;
        return true;
        }

        //匹配身份證(15位或18位)
        function isidcard(str)
        {
        var result=str.match(/d{15}|d{18}/);
        if(result==null) return false;
        return true;
        }
        //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

        ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

        //校驗文本是否為空
        function checknull(field,sval)
        {
        if (field.value ==””)
        {
        alert(“請填寫” + sval + “!”);
        field.focus();
        return false;
        }
        return true;
        }

        //屏蔽輸入字符
        /***********************
        調用方法:
        在文本框中加上 onkeypress=”return checkChar()”
        *************************/
        function checkChar()
        {
        var keycode = event.keyCode;
        if(!(keycode>=48&&keycode<=57))
        {
        return false;
        }
        }

        /***************************************************************************************************************************
        中國電話號碼驗證
        匹配形式如:0511-4405222 或者021-87888822 或者 021-44055520-555 或者 (0511)4405222
        正則表達式 “((d{3,4})|d{3,4}-)?d{7,8}(-d{3})*”

        中國郵政編碼驗證
        匹配形式如:215421
        正則表達式 “d{6}”

        電子郵件驗證
        匹配形式如:justali@justdn.com
        正則表達式 “w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*”

        身份證驗證
        匹配形式如:15位或者18位身份證
        正則表達式 “d{18}|d{15}”

        常用數字驗證
        正則表達式
        “d{n}” n為規定長度
        “d{n,m}” n到m的長度范圍

        非法字符驗證
        匹配非法字符如:< > & / ‘ |
        正則表達式 [^<>&/|’]+

        日期驗證
        匹配形式如:20030718,030718
        范圍:1900–2099
        正則表達式((((19){1}|(20){1})d{2})|d{2})[01]{1}d{1}[0-3]{1}d{1}

        匹配中文字符的正則表達式: [u4e00-u9fa5]
        評注:匹配中文還真是個頭疼的事,有了這個表達式就好辦了

        匹配雙字節字符(包括漢字在內):[^x00-xff]
        評注:可以用來計算字符串的長度(一個雙字節字符長度計2,ASCII字符計1)

        匹配空白行的正則表達式:ns*r
        評注:可以用來刪除空白行

        匹配HTML標記的正則表達式:< (S*?)[^>]*>.*?|< .*? />
        評注:網上流傳的版本太糟糕,上面這個也僅僅能匹配部分,對于復雜的嵌套標記依舊無能為力

        匹配首尾空白字符的正則表達式:^s*|s*$
        評注:可以用來刪除行首行尾的空白字符(包括空格、制表符、換頁符等等),非常有用的表達式

        匹配Email地址的正則表達式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
        評注:表單驗證時很實用

        匹配網址URL的正則表達式:[a-zA-z]+://[^s]*
        評注:網上流傳的版本功能很有限,上面這個基本可以滿足需求

        匹配帳號是否合法(字母開頭,允許5-16字節,允許字母數字下劃線):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
        評注:表單驗證時很實用

        匹配國內電話號碼:d{3}-d{8}|d{4}-d{7}
        評注:匹配形式如 0511-4405222 或 021-87888822

        匹配騰訊QQ號:[1-9][0-9]{4,}
        評注:騰訊QQ號從10000開始

        匹配中國郵政編碼:[1-9]d{5}(?!d)
        評注:中國郵政編碼為6位數字

        匹配身份證:d{15}|d{18}
        評注:中國的身份證為15位或18位

        匹配ip地址:d+.d+.d+.d+
        評注:提取ip地址時有用

        提取信息中的ip地址:
        (d+).(d+).(d+).(d+)

        提取信息中的中國手機號碼:
        (86)*0*13d{9}

        提取信息中的中國固定電話號碼:
        ((d{3,4})|d{3,4}-|s)?d{8}

        提取信息中的中國電話號碼(包括移動和固定電話):
        ((d{3,4})|d{3,4}-|s)?d{7,14}

        提取信息中的中國郵政編碼:
        [1-9]{1}(d+){5}

        提取信息中的中國身份證號碼:
        d{18}|d{15}

        提取信息中的整數:
        d+

        提取信息中的浮點數(即小數):
        (-?d*).?d+

        提取信息中的任何數字 :
        (-?d*)(.d+)?

        提取信息中的中文字符串:
        [u4e00-u9fa5]*

        提取信息中的雙字節字符串 (漢字):
        [^x00-xff]*

        提取信息中的英文字符串:
        w*
        提取信息中的網絡鏈接:
        (h|H)(r|R)(e|E)(f|F) *= *(‘|”)?(w|\|/|.)+(‘|”| *|>)?

        提取信息中的郵件地址:
        w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*

        提取信息中的圖片鏈接:
        (s|S)(r|R)(c|C) *= *(‘|”)?(w|\|/|.)+(‘|”| *|>)?

        匹配特定數字:
        ^[1-9]d*$    //匹配正整數
        ^-[1-9]d*$   //匹配負整數
        ^-?[1-9]d*$   //匹配整數
        ^[1-9]d*|0$  //匹配非負整數(正整數 + 0)
        ^-[1-9]d*|0$   //匹配非正整數(負整數 + 0)
        ^[1-9]d*.d*|0.d*[1-9]d*$   //匹配正浮點數
        ^-([1-9]d*.d*|0.d*[1-9]d*)$  //匹配負浮點數
        ^-?([1-9]d*.d*|0.d*[1-9]d*|0?.0+|0)$  //匹配浮點數
        ^[1-9]d*.d*|0.d*[1-9]d*|0?.0+|0$   //匹配非負浮點數(正浮點數 + 0)
        ^(-([1-9]d*.d*|0.d*[1-9]d*))|0?.0+|0$  //匹配非正浮點數(負浮點數 + 0)
        評注:處理大量數據時有用,具體應用時注意修正

        匹配特定字符串:
        ^[A-Za-z]+$  //匹配由26個英文字母組成的字符串
        ^[A-Z]+$  //匹配由26個英文字母的大寫組成的字符串
        ^[a-z]+$  //匹配由26個英文字母的小寫組成的字符串
        ^[A-Za-z0-9]+$  //匹配由數字和26個英文字母組成的字符串
        ^w+$  //匹配由數字、26個英文字母或者下劃線組成的字符串
        評注:最基本也是最常用的一些表達式

        ////////////////////前4行程序用于保護js代碼不被下載
        // ////////////////////基本正則表達式///////////////////
        //非空驗證 function NotNull (str) { return (str!=””); }
        //郵件地址驗證
        function checkEmail (str) {
        //郵件地址正則表達式 isEmail1=/^w+([.-]w+)*@w+([.-]w+)*.w+$/;
        //郵件地址正則表達式 isEmail2=/^.*@[^_]*$/;
        //驗證郵件地址,返回結果 return (isEmail1.test(str)&&isEmail2.test(str));
        } //身份證驗證 function checkIDCard (str) {
        //身份證正則表達式(15位)
        isIDCard1=/^[1-9]d{7}((0d)|(1[0-2]))(([0|1|2]d)|3[0-1])d{3}$/;
        //身份證正則表達式(18位) isIDCard2=/^[1-9]d{5}[1-9]d{3}((0d)|(1[0-2]))(([0|1|2]d)|3[0-1])d{4}$/;
        //驗證身份證,返回結果 return (isIDCard1.test(str)||isIDCard2.test(str)); }
        //IP驗證 function checkIP (str)
        { //IP正則表達式 IP='(25[0-5]|2[0-4]\d|1\d\d|\d\d|\d)’;
        IPdot=IP+’\.’; isIPaddress=new RegExp(‘^’+IPdot+IPdot+IPdot+IP+’$’);
        //驗證IP,返回結果 return (isIPaddress.test(str)); }
        //主頁(網址)驗證 function checkHomepage (str) {
        //主頁正則表達式 //isHomepage=/^w+([.-]w)*$/; isHomepage=/^w+(.w+)+.w+$/;
        //驗證主頁,返回結果 return (isHomepage.test(str)); }
        //是否數字 function isNum (str) { //isNumber=/^([1-9]d*(.d+)?)|(d+(.d+))$/; isNumber=/^d+(.d+)?$/;
        //驗證并返回結果 return (isNumber.test(str)); }
        //是否整數 function isInt (str) { isInteger=/^d+$/;
        //驗證并返回結果 return (isInteger.test(str)); }
        //是否字母 function isChar (str) { isCharacter=/^[A-Za-z]+$/;
        //驗證并返回結果 return (isCharacter.test(str)); }
        /////////////////////基本彈出窗口///////////////////
        function checkBoolean(bv,i,w) { if(bv==false) { try{i.focus();}catch(e){} alert(w); return false; } return true }
        ////////////////////元素和取值判斷//////////////////// //
        已選擇 function checkElement_selected(item,alert_str) { if(item.type==”select-one”)return checkElement_NotNull(item,alert_str); if(alert_str.length==0)alert_str=item.title+”為必選項!”; rt=false; if(item.length>0) { for(i=0;i<item.length;i++){rt=rt||item[i].checked;} } else { rt=item.checked } return checkBoolean(rt,item[0],alert_str); return true; } //
        不為空 function checkElement_NotNull(a,alert_str,g) { v=a.value; w=alert_str; if(alert_str.length==0)w=a.title+”不能為空!”; return(checkValue_NotNull(v,a,w,g)); } function checkValue_NotNull(v,i,w,g) { if(g!=”NOT_TRIM”)v=v.replace(/(^s*)|(s*$)/g, “”); bv=NotNull(v); return(checkBoolean(bv,i,w)); }
        // 合法郵箱 function checkElement_IsEmail(a,alert_str,g) { v=a.value; w=alert_str; if(alert_str.length==0)w=a.title+”不能為空!”; return(checkValue_IsEmail(v,a,w,g)); }
        function checkValue_IsEmail(v,i,w,g) { if(g!=”NOT_TRIM”)v=v.replace(/(^s*)|(s*$)/g, “”); bv=checkEmail(v); return(checkBoolean(bv,i,w)); } // 合法身份證 function checkElement_IsIDCard(a,alert_str,g) { v=a.value; w=alert_str; if(alert_str.length==0)w=a.title+”不能為空!”; return(checkValue_IsIDCard(v,a,w,g)); }
        function checkValue_IsIDCard(v,i,w,g) { if(g!=”NOT_TRIM”)v=v.replace(/(^s*)|(s*$)/g, “”); bv=checkIDCard(v); return(checkBoolean(bv,i,w)); } // 合法IP function checkElement_IsIP(a,alert_str,g) { v=a.value; w=alert_str; if(alert_str.length==0)w=a.title+”不能為空!”; return(checkValue_IsIP(v,a,w,g)); } function checkValue_IsIP(v,i,w,g) { if(g!=”NOT_TRIM”)v=v.replace(/(^s*)|(s*$)/g, “”); bv=checkIP(v); return(checkBoolean(bv,i,w)); }
        // 驗證數字 function checkElement_IsNum(a,alert_str,g) { v=a.value; w=alert_str; if(alert_str.length==0)w=a.title+”不能為空!”; return(checkValue_IsNum(v,a,w,g)); } function checkValue_IsNum(v,i,w,g) { if(g!=”NOT_TRIM”)v=v.replace(/(^s*)|(s*$)/g, “”); bv=isNum(v); return(checkBoolean(bv,i,w)); }
        // 驗證整數 function checkElement_IsInt(a,alert_str,g) { v=a.value; w=alert_str; if(alert_str.length==0)w=a.title+”不能為空!”; return(checkValue_IsInt(v,a,w,g)); } function checkValue_IsInt(v,i,w,g) { if(g!=”NOT_TRIM”)v=v.replace(/(^s*)|(s*$)/g, “”); bv=isInt(v); return(checkBoolean(bv,i,w)); } // 驗證字母 function checkElement_IsChar(a,alert_str,g) { v=a.value; w=alert_str; if(alert_str.length==0)w=a.title+”不能為空!”; return(checkValue_IsChar(v,a,w,g)); } function checkValue_IsChar(v,i,w,g) { if(g!=”NOT_TRIM”)v=v.replace(/(^s*)|(s*$)/g, “”); bv=isChar(v); return(checkBoolean(bv,i,w)); }
        // 合法主頁 function checkElement_IsHomepage(a,alert_str,g) { v=a.value; w=alert_str; if(alert_str.length==0)w=a.title+”不能為空!”; return(checkValue_IsHomepage(v,a,w,g)); } function checkValue_IsHomepage(v,i,w,g) { if(g!=”NOT_TRIM”)v=v.replace(/(^s*)|(s*$)/g, “”); bv=checkHomepage(v); return(checkBoolean(bv,i,w)); }

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国产精品白浆在线观看免费| 99RE8这里有精品热视频| 6一12呦女精品| 久久996热精品xxxx| 精品国产福利第一区二区三区| 亚洲精品国产av成拍色拍| 国产精品哟女在线观看| 97久久精品无码一区二区天美| 麻豆精品| 国产精品视频全国免费观看 | 国产在线精品一区二区不卡| 午夜欧美精品久久久久久久| 欧美精品91欧美日韩操| 大胸国产精品视频| 精品亚洲综合久久中文字幕| 成人精品在线视频| 东京热TOKYO综合久久精品| 亚洲AV永久无码精品水牛影视| 亚洲精品成人在线| 欧美精品一区二区在线精品 | 欧美精品hdvideosex4k| 中文字幕久久精品| 亚洲精品宾馆在线精品酒店| 久久精品国产一区二区| 精品91自产拍在线观看二区| 国产成人精品大尺度在线观看| 精品久久久久国产免费| 久久99精品久久久久久9蜜桃| 国产91精品在线观看| 国产suv精品一区二区33| 国产AV午夜精品一区二区入口| 国内精品人妻无码久久久影院| 精品亚洲成a人片在线观看 | 2021国产三级精品三级在专区| 桃花岛精品亚洲国产成人| 国产精品一二二区| 久久精品视频免费| 在线精品视频播放| 国产精品伦理久久久久久| 国产在线观看一区精品| 精品久久久久久无码中文野结衣|