亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

簡單的js表單驗證函數

2019-11-20 21:50:22
字體:
來源:轉載
供稿:網友
網站制作中,表單驗證的功能是很常用的。
有些時候,用一些成型的js控件會比較方便,但是又過于龐大和難以維護(本人的js水平不高)
所以干脆自己寫了一個。至于好不好,靈活不靈活,還請大家指點(先上圖,很難看,請不要介意):


代碼:

復制代碼 代碼如下:

表單驗證js代碼

var fv =
{
    lang: "zh-cn",  //錯誤提示語言
    inValidedStr: "=",  //初始隨意復制,使其長度不為0
    mail: function(elementID)   //驗證郵件地址合法,elementID為input文本輸入框的ID
    {
        if (elementID == null) { return true; }
        else
        {
            var reg = /^[/w-]+(/.[/w-]+)*@[/w-]+(/.[/w-]+)+$/;
            if (reg.test(document.getElementById(elementID).value))
            {
                fv.inValidedStr = fv.inValidedStr.replace(/mail/g, "");
                fv.inValidedStr = fv.inValidedStr.replace("=", "");
                validMsg(fv.lang, "mail", "mailInfo");
            }
            else
            {
                fv.inValidedStr = fv.inValidedStr + "mail";
                errorMsg(fv.lang, "mail", "mailInfo");
            }
        }
    },
    username: function(elementID)   //驗證用戶名合法 字母數字下劃線,長度為6-20
    {
        if (elementID == null) { return true; }
        else
        {
            var reg = /^[a-zA-Z0-9_]{5,19}$/;
            if (reg.test(document.getElementById(elementID).value))
            {
                fv.inValidedStr = fv.inValidedStr.replace(/username/g, "");
                fv.inValidedStr = fv.inValidedStr.replace("=", "");
                validMsg(fv.lang, "username", "usernameInfo");
            }
            else
            {
                fv.inValidedStr = fv.inValidedStr + "username";
                errorMsg(fv.lang, "username", "usernameInfo");
            }
        }
    },

    //....可以加其他驗證
    isValid: function() { return (fv.inValidedStr.length == 0); }
};

//驗證成功時的信息 elementID 為信息提示的html單元的id
function validMsg(lang, valueType, elementID)
{
    var msgInfo = "";
    var isCn = lang == "zh-cn";

    switch (valueType)
    {
        case "mail":
            msgInfo = isCn ? " √ 地址正確" : " √ the mail address is valided";
            break;
        case "username":
            msgInfo = isCn ? " √ 成功" : " √ The account valided ";
            break;
        case "password":
            msgInfo = isCn ? " √ 成功" : " √ Valided format!";
            break;
        //.....對應增加其他情況
        default:
            break;
    }
    document.getElementById(elementID).innerHTML = msgInfo;
    document.getElementById(elementID).style.color = "green";
}

//驗證失敗時的信息
function errorMsg(lang, valueType, elementID)
{
    var msgInfo = "";
    var isCn = lang == "zh-cn";

    switch (valueType)
    {
        case "mail":
            msgInfo = isCn ? " × 請輸入正確的郵件地址" : " × The e-mail format is error,plz input right format .eg. abc@def.com.";
            break;
        case "username":
            msgInfo = isCn ? " × 長度6-20個字符,只能為數字,字母,下劃線組成" : " × The account just ";
            break;
        case "password":
            msgInfo = isCn ? " × 密碼為……" : " × inValided format!";
            break;
        //....對應增加其他情況
        default:
            break;
    }
        document.getElementById(elementID).innerHTML = msgInfo;
        document.getElementById(elementID).style.color = "red";
}


前臺代碼(aspx頁面):
復制代碼 代碼如下:

前臺aspx頁面代碼

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <script type="text/javascript" src="Common/Js/formValid.js"></script>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <script type="text/javascript">fv.lang = "en"/*如去掉此行,則默認為中文提示*/</script>
        <input type="text" name="mail" id="mail" onblur="fv.mail('mail')" /><span id="mailInfo"></span><br />
        <asp:TextBox ID="username" runat="server" onblur="fv.username('username')"></asp:TextBox><span id="usernameInfo"></span><br />
        <input type="submit" onclick="return fv.isValid()" value="Submit" />
    </div>
    </form>
</body>
</html>

然后,如果需要其他的驗證,則加入即可。相關正則表達式

復制代碼 代碼如下:

匹配中文字符的正則表達式: [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地址時有用

匹配特定數字:
^[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個英文字母或者下劃線組成的字符串
在使用RegularExpressionValidator驗證控件時的驗證功能及其驗證表達式介紹如下:
只能輸入數字:“^[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]*$”
只能輸入長度為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之間,

只能包含字符、數字和下劃線。
驗證是否含有^%&',;=?前臺aspx頁面代碼<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <script type="text/javascript" src="Common/Js/formValid.js"></script>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <script type="text/javascript">fv.lang = "en"/*如去掉此行,則默認為中文提示*/</script>
        <input type="text" name="mail" id="mail" onblur="fv.mail('mail')" /><span id="mailInfo"></span><br />
        <asp:TextBox ID="username" runat="server" onblur="fv.username('username')"></asp:TextBox><span id="usernameInfo"></span><br />
        <input type="submit" onclick="return fv.isValid()" value="Submit" />
    </div>
    </form>
</body>
</html>



XXquot;等字符:“[^%&',;=?$x22]+”
只能輸入漢字:“^[u4e00-u9fa5],{0,}$”
驗證Email地址:“^w+[-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$”
驗證InternetURL:“^http://([w-]+.)+[w-]+(/[w-./?%&=]*)?$”
驗證電話號碼:“^((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”。

匹配中文字符的正則表達式: [u4e00-u9fa5]
匹配雙字節字符(包括漢字在內):[^x00-xff]
匹配空行的正則表達式:n[s| ]*r
匹配HTML標記的正則表達式:/< (.*)>.*|< (.*) />/
匹配首尾空格的正則表達式:(^s*)|(s*$)
匹配Email地址的正則表達式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
匹配網址URL的正則表達式:http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?
(1)應用:計算字符串的長度(一個雙字節字符長度計2,ASCII字符計1)
String.prototype.len=function(){return this.replace([^x00-xff]/g,"aa").length;}
(2)應用:javascript中沒有像vbscript那樣的trim函數,我們就可以利用這個表達式來實現
String.prototype.trim = function()
{
return this.replace(/(^s*)|(s*$)/g, "");
}
(3)應用:利用正則表達式分解和轉換IP地址
function IP2V(ip) //IP地址轉換成對應數值
{
re=/(d+).(d+).(d+).(d+)/g //匹配IP地址的正則表達式
if(re.test(ip))
{
return RegExp.$1*Math.pow(255,3))+RegExp.$2*Math.pow(255,2))+RegExp.$3*255+RegExp.$4*1
}
else
{
throw new Error("Not a valid IP address!")
}
}
(4)應用:從URL地址中提取文件名的javascript程序
s="http://www.49028c.com/page1.htm";
s=s.replace(/(.*/){0,}([^.]+).*/ig,"$2") ; //Page1.htm
(5)應用:利用正則表達式限制網頁表單里的文本框輸入內容
用正則表達式限制只能輸入中文:onkeyup="value="/blog/value.replace(/["^u4E00-u9FA5]/g,'') " onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^u4E00-u9FA5]/g,''))"
用正則表達式限制只能輸入全角字符: onkeyup="value="/blog/value.replace(/["^uFF00-uFFFF]/g,'') " onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^uFF00-uFFFF]/g,''))"
用正則表達式限制只能輸入數字:onkeyup="value="/blog/value.replace(/["^d]/g,'') "onbeforepaste= "clipboardData.setData('text',clipboardData.getData('text').replace(/[^d]/g,''))"
用正則表達式限制只能輸入數字和英文:onkeyup="value="/blog/value.replace(/[W]/g,"'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^d]/g,''

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品久久av| 狠狠躁18三区二区一区| 中文字幕久热精品在线视频| 亚洲福利在线播放| 欧美噜噜久久久xxx| 中文字幕亚洲欧美日韩高清| 91欧美激情另类亚洲| 欧美一区二区视频97| 亚洲国产精品一区二区久| 性色av香蕉一区二区| 国产精品高清在线观看| 国产欧美日韩精品专区| 成人在线观看视频网站| 亚洲欧美色图片| 成人久久18免费网站图片| 91av在线免费观看| 欧美大人香蕉在线| 国产亚洲精品久久久久久| 国产第一区电影| 亚洲嫩模很污视频| 精品久久久久久久久久| 精品亚洲va在线va天堂资源站| 日韩成人av网址| 亚洲精品国产精品国自产在线| 精品国产福利在线| 亚洲三级av在线| 亚洲激情小视频| 成人免费看吃奶视频网站| 在线观看视频亚洲| 97久久久免费福利网址| 久久五月天色综合| 久久久久国产精品www| 色婷婷av一区二区三区久久| 亚洲va欧美va国产综合久久| 日韩精品在线观看一区二区| 中文字幕欧美国内| 欧美视频在线观看免费网址| 亚洲国产精品久久久| 日韩视频在线一区| 欧美日韩在线第一页| 欧亚精品在线观看| 国产91精品久久久久久| 欧美性猛交xxxx富婆| 国产婷婷色综合av蜜臀av| 欧美日韩国产专区| 国产欧美一区二区| 成年人精品视频| 最新69国产成人精品视频免费| 91chinesevideo永久地址| 亚洲天堂av网| 国产精品丝袜一区二区三区| 91精品久久久久久久久不口人| 日韩av最新在线| 久久精品亚洲一区| 亚洲天堂av电影| 91国产精品91| 亚洲香蕉成视频在线观看| 亚洲伊人一本大道中文字幕| 成人性生交大片免费看小说| 久久久久久久久综合| 4444欧美成人kkkk| 98精品国产高清在线xxxx天堂| 日本国产一区二区三区| 亚洲精品日韩丝袜精品| 国产精品扒开腿做爽爽爽视频| 国产精品一区av| 日韩av黄色在线观看| 国产精品入口夜色视频大尺度| 国产精品入口免费视频一| 96pao国产成视频永久免费| 欧美日韩成人黄色| 日本一区二区三区在线播放| zzijzzij亚洲日本成熟少妇| 91在线看www| 亚洲人成亚洲人成在线观看| 中文字幕免费精品一区| 91精品国产91久久久久久最新| 欧美插天视频在线播放| 日韩二区三区在线| 综合136福利视频在线| 亚洲欧美国产制服动漫| 亚洲最大的av网站| 日本午夜在线亚洲.国产| 欧美日韩亚洲精品一区二区三区| 97热精品视频官网| 国产精品免费久久久久影院| 国产精品久久久久高潮| 日韩久久免费视频| 欧美成人性色生活仑片| 久久久精品一区二区三区| 久久精品欧美视频| 黑丝美女久久久| 国产精品一二三视频| 91精品一区二区| 亚洲午夜精品久久久久久性色| 欧美疯狂性受xxxxx另类| www欧美xxxx| 久久亚洲综合国产精品99麻豆精品福利| 色综合导航网站| 欧美国产高跟鞋裸体秀xxxhd| 免费成人高清视频| 欧美在线视频免费播放| 亚洲2020天天堂在线观看| 亚洲国产另类 国产精品国产免费| 色诱女教师一区二区三区| 国产精品欧美日韩一区二区| 亚洲色图35p| 91青草视频久久| 国产精品成人久久久久| 亚洲精品99久久久久中文字幕| 黑人巨大精品欧美一区二区免费| 欧美成人激情视频免费观看| 有码中文亚洲精品| 欧美激情精品久久久| 亚洲片av在线| 欧美风情在线观看| 亚洲国产中文字幕久久网| 韩曰欧美视频免费观看| 日韩电影在线观看免费| 国产精品日韩在线观看| 久久精品99国产精品酒店日本| 国产激情久久久久| 亚州精品天堂中文字幕| 国产免费一区视频观看免费| 久99九色视频在线观看| 久久久999成人| 伊人久久久久久久久久久| 91地址最新发布| 国产成人精品电影| 日韩av不卡在线| 欧美一区二区三区……| 日本国产一区二区三区| 国产精品爱啪在线线免费观看| 久久久人成影片一区二区三区| 热久久视久久精品18亚洲精品| 久久久久久久久久久国产| 国产精品久久久久高潮| 国产精品第七影院| 91精品在线观看视频| 国产精品一区二区三区在线播放| 2019中文字幕免费视频| 97精品在线视频| 国产综合在线视频| 欧美激情综合色| 色噜噜狠狠狠综合曰曰曰| 成人黄色免费片| 亚洲天堂免费观看| 蜜臀久久99精品久久久无需会员| 久久精品视频在线播放| www.欧美视频| 日韩亚洲综合在线| 91最新在线免费观看| 91精品久久久久久久久青青| 日韩中文字幕在线视频| 中文字幕在线观看日韩| 亚洲高清久久久久久| 亚洲免费伊人电影在线观看av| 日韩精品在线免费观看视频| 黑人精品xxx一区一二区| 国产一区二区三区在线视频| 亚洲免费视频观看| 亚洲成色www8888| 国产在线日韩在线| 成人淫片在线看|