欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

简单的js表单验证函数

程序员文章站 2023-11-13 08:04:10
网站制作中,表单验证的功能是很常用的。有些时候,用一些成型的js控件会比较方便,但是又过于庞大和难以维护(本人的js水平不高)所以干脆自己写了一个。至于好不好,灵活不灵活,还请大家指点(先上图,很难看...
网站制作中,表单验证的功能是很常用的。
有些时候,用一些成型的js控件会比较方便,但是又过于庞大和难以维护(本人的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="https://www.jb51.net/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,''