jQuery 验证插件 Web前端设计模式(asp.net)


Posted in Javascript onOctober 17, 2010

设计目标:建立一个基于jQuery框架的通用Web验证插件...

设计要求:1.需要漂亮的css样式及小图标的润饰...
2.基于jQuery框架...
3.调用.net Web 服务来实现与数据库的异步交互...

解决方案:1、首先,我们来设计三个类,分别用来显示Web给用户的视觉感知。它们分别是
.msg_warning{font-family:Arial,Helvetica,sans-serif,simsun; background:#e7f7ff url(register/MsgWarning.gif) no-repeat;border:solid 1px #6cf;color:#333;padding:0 0 0 36px !important;width:220px; margin-left:20px;}
.msg_error{font-family:Arial,Helvetica,sans-serif,simsun;background:#fff3ef url(register/MsgError.jpg) no-repeat;border:solid 1px #ff6610;color:#333;padding:0 0 0 36px !important;width:220px; margin-left:20px;}

.msg_ok{font-family:Arial,Helvetica,sans-serif,simsun;background:#e7ffe7 url(register/MsgOk.gif) no-repeat;border:solid 1px #95e895;color:#333;padding:0 0 0 36px !important;width:220px; margin-left:20px;}
分别是验证错误,验证警告和验证正确时候的不同样式...
2. 在相应的位置放置图片,如样式中的所示,包含MsgWarning.gif,MsgError.jpg,MsgOk.gif三张小图片分别对应.msg_warning;.msg_error;.msg_ok;

3.开始编写脚本
(1)、//去掉空值

String.prototype.trim = function() 
{ 
var x = this; 
x = x.replace(/^\s*(.*)/, "$1"); 
return x; 
}

这个函数用以去掉文本框中的空位置(trim)...

(2)、写两个数组,用以存放触发验证时的提示语句和样式...
var ErrorWords = ['正确!', '不能为空!', 'E-mail地址长度不能超过50位!', '请输入正确的邮箱格式!',"密码必须大于6个,少于16个!","密钥不配对!",'公司名称不能超过50位!',"区号和号码均不为空!","区号为4位数字!","号码为7-10位的数字!","QQ号码为5-12位数字!",'地址长度不超过50位!','名字为10位以内的中文!','手机号为11位数字!','邮编为6位数字!','用户名为3-15位之间!','域名格式错误!','该用户名已注册!','该邮箱已被注册!']

var ErrorClass = ['msg_ok', 'msg_warning', 'msg_warning', 'msg_error', 'msg_warning', 'msg_error', 'msg_warning', 'msg_warning', 'msg_error','msg_error','msg_error','msg_error','msg_error','msg_error','msg_error','msg_error','msg_error','msg_error','msg_error']

(3)、开始编写各种验证类型,我写了所有我能够想到的...

;(function($){ 
//闭包邮箱核对 
jQuery.fn.extend({ 
"checkEmail":function() //封装成checkEmail()函数 
{ 
$(this).blur(function(){ 
var check; 
var email=$(this).val().toLowerCase(); 
var strSuffix = "cc|com|edu|gov|int|net|org|biz|info|pro|name|coop|al|dz|af|ar|ae|aw|om|az|eg|et|ie|ee|ad|ao|ai|ag|at|au|mo|bb|pg|bs|pk|py|ps|bh|pa|br|by|bm|bg|mp|bj|be|is|pr|ba|pl|bo|bz|bw|bt|bf|bi|bv|kp|gq|dk|de|tl|tp|tg|dm|do|ru|ec|er|fr|fo|pf|gf|tf|va|ph|fj|fi|cv|fk|gm|cg|cd|co|cr|gg|gd|gl|ge|cu|gp|gu|gy|kz|ht|kr|nl|an|hm|hn|ki|dj|kg|gn|gw|ca|gh|ga|kh|cz|zw|cm|qa|ky|km|ci|kw|cc|hr|ke|ck|lv|ls|la|lb|lt|lr|ly|li|re|lu|rw|ro|mg|im|mv|mt|mw|my|ml|mk|mh|mq|yt|mu|mr|us|um|as|vi|mn|ms|bd|pe|fm|mm|md|ma|mc|mz|mx|nr|np|ni|ne|ng|nu|no|nf|na|za|aq|gs|eu|pw|pn|pt|jp|se|ch|sv|ws|yu|sl|sn|cy|sc|sa|cx|st|sh|kn|lc|sm|pm|vc|lk|sk|si|sj|sz|sd|sr|sb|so|tj|tw|th|tz|to|tc|tt|tn|tv|tr|tm|tk|wf|vu|gt|ve|bn|ug|ua|uy|uz|es|eh|gr|hk|sg|nc|nz|hu|sy|jm|am|ac|ye|iq|ir|il|it|in|id|uk|vg|io|jo|vn|zm|je|td|gi|cl|cf|cn"; 
var regu = "^[a-z0-9][_a-z0-9\-]*([\.][_a-z0-9\-]+)*@([a-z0-9\-_]+[\.])+(" + strSuffix + ")$"; 
var re = new RegExp(regu); 
if(email.trim()=='') check=1; 
else if(email.length > 50) check=2; 
else if(email.search(re) == -1) check=3; 
else { check=0;} 
$(this).next().remove("span"); 
$(this).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
}) 
} 
}) 
=========================================================== 
//闭包密码验证s 
jQuery.fn.extend({ 
"checkCode":function() 
{ 
$(this).blur(function(){ 
var check; 
var pwd=$(this).val(); 
var path = /^[a-zA-Z0-9_]{6,16}$/; 
if(pwd.trim()=='') check=1; 
else if(!path.test(pwd)) check=4; 
else check=0; 
$(this).next().remove("span"); 
$(this).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
}) 
} 
}) 
//闭包密码重复核对 
jQuery.fn.extend({ 
"checkCode2":function(pwd) 
{ 
$(this).blur(function(){ 
var check; 
var pwd2=$(this).val(); 
if(pwd2.trim()=='') check=1; 
else if(pwd2!=$(pwd).val()) check=5; 
else check=0; 
$(this).next().remove("span"); 
$(this).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
}) 
} 
}) 
=========================================================================== 
//闭包公司名称核对 
jQuery.fn.extend({ 
"checkCPName":function() 
{ 
$(this).blur(function(){ 
var check; 
var CPName=$(this).val(); 
if(CPName.trim()=='') check=1; 
else if(CPName.length>50) check=6; 
else check=0; 
$(this).next().remove("span"); 
$(this).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
}) 
} 
}) ========================================================================== 
//闭包公司电话/传真核对 
jQuery.fn.extend({ 
"checkTel":function() 
{ 
$(this).blur(function(){ 
var check; 
var names=$(this).attr("name"); 
var check1=$("input[name='"+names+"']").eq(0).val(); 
var check2=$("input[name='"+names+"']").eq(1).val(); 
var path1 = /^[0-9]{4}$/; 
var path2= /^[0-9]{7,10}$/; 
if(check1.trim() == ''|| check2.trim()=='') check=7; 
else if(!path1.test(check1)) check=8; 
else if(!path2.test(check2)) check=9; 
else check=0; 
$("input[name='"+names+"']").eq(1).next().remove("span"); 
$("input[name='"+names+"']").eq(1).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
}) 
} 
}) 
======================================================================================= 
//闭包QQ/MSN核对 
jQuery.fn.extend({ 
"checkQQ":function() 
{ 
$(this).blur(function(){ 
var check; 
var CPQQ=$(this).val(); 
var path= /^[0-9]{5,12}$/; 
if(CPQQ.trim()=='') check=1; 
else if(!path.test(CPQQ)) check=10; 
else check=0; 
$(this).next().remove("span"); 
$(this).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
}) 
} 
}) 
======================================================================================= 
//闭包地址核对 
jQuery.fn.extend({ 
"checkAdd":function() 
{ 
$(this).blur(function(){ 
var check; 
var CPAdd=$(this).val(); 
if(CPAdd.trim()=='') check=1; 
else if(CPAdd.length>50) check=11; 
else check=0; 
$(this).next().remove("span"); 
$(this).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
}) 
} 
}) 
========================================================================================= 
//闭包用户真实姓名核对 利用函数返回程序结果 
jQuery.fn.extend({ 
"checkRealName":function() 
{ 
var check; 
$(this).blur(function(){ 
var realName=$(this).val(); 
var reg = /^[\u4e00-\u9fa5]{1,10}$/gi; 
if(realName.trim()=='') check=1; 
else if(!reg.test(realName)) check=12; 
else check=0; 
$(this).next().remove("span"); 
$(this).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
return check; 
}) 
} 
}) 
================================================================================= 
//闭包手机号码核对 
jQuery.fn.extend({ 
"checkPhone":function() 
{ 
$(this).blur(function(){ 
var check; 
var telephone=$(this).val(); 
var reg=/^[0-9]{11}$/; 
if(telephone.trim()=='') check=1; 
else if(!reg.test(telephone)) check=13; 
else check=0; 
$(this).next().remove("span"); 
$(this).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
}) 
} 
}) 
=========================================================================================== 
//闭包邮编核对 
jQuery.fn.extend({ 
"checkPCode":function() 
{ 
$(this).blur(function(){ 
var check; 
var PCode=$(this).val(); 
var reg=/^[0-9]{6}$/; 
if(PCode=='') check=1; 
else if(!reg.test(PCode)) check=14; 
else check=0; 
$(this).next().remove("span"); 
$(this).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
}) 
} 
}) 
========================================================================================== 
//闭包用户名核对 
jQuery.fn.extend({ 
"checkUserName":function() 
{ 
$(this).blur(function(){ 
var check; 
var UserName=$(this).val(); 
if(UserName=='') check=1; 
else if(UserName.length<3 || UserName.length>15) check=15; 
else check=0; 
$(this).next().remove("span"); 
$(this).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
}) 
} 
}) 
================================================================================ 
//闭包域名验证 
jQuery.fn.extend({ 
"checkSite":function() 
{ 
$(this).blur(function(){ 
var check; 
var WebSite=$(this).val(); 
var reg= /http(s)?:\/\/([\w-]+\.)+[\w-]+(\/[\w- .\/?%&=]*)?/; 
if(WebSite=='') check=1; 
else if(!reg.test(WebSite)) check=16; 
else check=0; 
$(this).next().remove("span"); 
$(this).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
}) 
} 
}) 
=================================================================================== 
//验证用户名是否存在数据库中(调用WebService方法) 
jQuery.fn.extend({ 
"nameAjax":function(LName,Lfun) 
{ 
$(this).blur(function(){ 
var check; 
var thisid=$(this).attr("id"); 
var logname=$(this).val(); 
if(logname=='') 
{ 
check=1; 
$("#"+thisid).next().remove("span"); 
$("#"+thisid).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
} 
else if(logname.length<3||logname.length>15) 
{ 
check=15; 
$(this).next().remove("span"); 
$(this).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
} 
else 
{ 
$.ajax({ 
type: "POST", 
contentType:"application/json;utf-8", 
url: "./WebService.asmx/"+LName, 
data:"{"+Lfun+":'"+logname+"'}", 
dataType: 'json', 
anysc:false, 
success:function(data) 
{ if(data.d) check=17; 
else check=0; 
$("#"+thisid).next().remove("span"); 
$("#"+thisid).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
} 
}) 
} 
}) 
} 
})

相对应的Web服务方法:

/// <summary> 
///这边核对登陆名是否存在,这边偷懒用随机验证 
/// </summary> 
/// <param name="logName"></param> 
/// <returns></returns> 
[WebMethod] 
public bool checkLogoName(string lognames) 
{ 
Random r = new Random(); 
int i = r.Next(1, 10000); 
if (i % 2 == 0) return true; 
return false; 
} 
========================================================================================= 
//验证用户邮箱是否在数据库中(调用Web服务的方法) 
jQuery.fn.extend({ 
"emailAjax":function(Lemail,Lfun) 
{ 
$(this).blur(function(){ 
var check; 
var thisid=$(this).attr("id"); 
var email=$(this).val().toLowerCase(); 
var strSuffix = "cc|com|edu|gov|int|net|org|biz|info|pro|name|coop|al|dz|af|ar|ae|aw|om|az|eg|et|ie|ee|ad|ao|ai|ag|at|au|mo|bb|pg|bs|pk|py|ps|bh|pa|br|by|bm|bg|mp|bj|be|is|pr|ba|pl|bo|bz|bw|bt|bf|bi|bv|kp|gq|dk|de|tl|tp|tg|dm|do|ru|ec|er|fr|fo|pf|gf|tf|va|ph|fj|fi|cv|fk|gm|cg|cd|co|cr|gg|gd|gl|ge|cu|gp|gu|gy|kz|ht|kr|nl|an|hm|hn|ki|dj|kg|gn|gw|ca|gh|ga|kh|cz|zw|cm|qa|ky|km|ci|kw|cc|hr|ke|ck|lv|ls|la|lb|lt|lr|ly|li|re|lu|rw|ro|mg|im|mv|mt|mw|my|ml|mk|mh|mq|yt|mu|mr|us|um|as|vi|mn|ms|bd|pe|fm|mm|md|ma|mc|mz|mx|nr|np|ni|ne|ng|nu|no|nf|na|za|aq|gs|eu|pw|pn|pt|jp|se|ch|sv|ws|yu|sl|sn|cy|sc|sa|cx|st|sh|kn|lc|sm|pm|vc|lk|sk|si|sj|sz|sd|sr|sb|so|tj|tw|th|tz|to|tc|tt|tn|tv|tr|tm|tk|wf|vu|gt|ve|bn|ug|ua|uy|uz|es|eh|gr|hk|sg|nc|nz|hu|sy|jm|am|ac|ye|iq|ir|il|it|in|id|uk|vg|io|jo|vn|zm|je|td|gi|cl|cf|cn"; 
var regu = "^[a-z0-9][_a-z0-9\-]*([\.][_a-z0-9\-]+)*@([a-z0-9\-_]+[\.])+(" + strSuffix + ")$"; 
var re = new RegExp(regu); 
if(email.trim()=='') { check=1;$(this).next().remove("span"); $(this).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); } 
else if(email.length > 50) { check=2; $(this).next().remove("span"); $(this).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); } 
else if(email.search(re) == -1) { check=3; $(this).next().remove("span"); $(this).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); } 
else 
{ 
$.ajax({ 
type: "POST", 
contentType:"application/json;utf-8", 
url: "./WebService.asmx/"+Lemail, 
data:"{"+Lfun+":'"+email+"'}", 
dataType: 'json', 
anysc:false, 
success:function(data) 
{ if(data.d) check=18; 
else check=0; 
$("#"+thisid).next().remove("span"); 
$("#"+thisid).after("<span class='"+ErrorClass[check]+"'>"+ErrorWords[check]+"</span>"); 
} 
}) 
} 
}) 
} 
})

相对应的Web服务方法:
/// <summary> 
/// 核对邮箱是否存在,这边偷懒用随机验证 
/// </summary> 
/// <param name="logemail"></param> 
/// <returns></returns> 
[WebMethod] 
public bool checkLogEmail(string logemails) 
{ 
Random r = new Random(); 
int i = r.Next(1, 10000); 
if (i % 2 == 0) return true; 
return false; 
} ===================================================================================== 
//最终提交 
jQuery.fn.extend({ 
"toReg":function(num) //这里的nun请注意,启用多少个验证就写多少数字,因为我将上面的15个验证都启用... 
{ 
$(this).click(function(){ 
var erolen=$(".msg_error").length; 
var warlen=$(".msg_warning").length; 
var oklen=$(".msg_ok").length; 
if(oklen==num) 
{ alert("验证通过..."); } 
else alert("错误:"+erolen+",警告:"+warlen+",通过:"+oklen+",请完整填写信息!"); 
}) 
} 
}) 
})(jQuery); 
=============================================================================================

4、在Web页面引入脚本
<script src="jQueryValidation/js/jquery-1.4.2.min.js" type="text/javascript"></script> 
<script src="jQueryValidation/js/wzh.Register.js" type="text/javascript"></script> <script type="text/javascript"> 
$(document).ready(function(){ 
$("#Emails").checkEmail();//验证Email 
$("#Codes").checkCode();//验证密码框一 
$("#Codes2").checkCode2("#Codes");//验证密码框二,参数为第一个密码框的ID 
$("#CPNames").checkCPName();//验证公司名称 
$("input[name='tel']").checkTel();//验证电话(格式:区号框和号码框需在同一个name下面,如tel) 
$("input[name='fax']").checkTel();//验证传真(格式:区号框和号码框需在同一个name下面,如tel) 
$("#QQs").checkQQ();//验证QQ号码 
$("#CPAdds").checkAdd();//验证公司地址 
$("#RealName").checkRealName();//验证真实姓名,10位以内的中文 
$("#Phones").checkPhone();//验证移动电话号码,11位 
$("#PCodes").checkPCode();//验证邮编 ,6位 
$("#UserName").checkUserName();//验证用户名 
$("#WebSites").checkSite();//验证网址 
$("#usernameAjax").nameAjax("checkLogoName","lognames");//Web服务中的函数名,参数名;方法在WebService中 
$("#uemailAjax").emailAjax("checkLogEmail","logemails");//Web服务中的函数名,参数名;方法在WebService中 
$("#register").toReg(15);//用户注册 
}) 
</script>

5.Web页面的HTML源码
<div> 
用户登录名核对:<input type="text" id="UserName" /><br /><br /> 
邮箱核对:<input type="text" id="Emails"/><br /><br /> 
密码核对:<input type="password" id="Codes"/><br /><br /> 
密码再对:<input type="password" id="Codes2"/><br /><br /> 
公司名称核对:<input type="text" id="CPNames"/><br /><br /> 
电话:区号:<input name="tel" type="text" id="txtTel1" size="8"/> 
- 
<input name="tel" type="text" id="txtTel2" size="16"/> 
<br /><br /> 
传真:区号:<input name="fax" type="text" id="txtFax1" size="8" /> 
- 
<input name="fax" type="text" id="txtFax2" size="16" /> <br /><br /> 
用户QQ:<input type="text" id="QQs"/><br /><br /> 
公司地址:<input type="text" id="CPAdds"/><br /><br /> 
用户真实姓名:<input type="text" id="RealName"/><br /><br /> 
手机号码核对:<input type="text" id="Phones"/><br /><br /> 
邮编核对:<input type="text" id="PCodes"/><br /><br /> 
域名验证:<input type="text" id="WebSites" value="htp://"/><br /><br /> 
(数据库)用户名验证:<input type="text" id="usernameAjax"/><br /><br /> 
(数据库)用户邮箱验证:<input type="text" id="uemailAjax"/><br /><br /> 
<input type="button" value="提交" id="register"/> 
</div> 
//至此全部结束

设计小结:还有很不不完善的地方,譬如未想到的验证,还有代码冗余度过大,希望使用的时候可以自己改良下...
源代码下载地址 http://xiazai.3water.com/201010/yuanma/jqueryRegister.rar

Javascript 相关文章推荐
用js做一个小游戏平台 (一)
Dec 29 Javascript
javascript dom代码应用 简单的相册[firefox only]
Jun 12 Javascript
两种方法基于jQuery实现IE浏览器兼容placeholder效果
Oct 14 Javascript
JS给超链接加确认对话框的方法
Feb 24 Javascript
超全面的JavaScript开发规范(推荐)
Jan 21 Javascript
Angular.js中angular-ui-router的简单实践
Jul 18 Javascript
利用jQuery+localStorage实现一个简易的计时器示例代码
Dec 25 jQuery
javascript实现最长公共子序列实例代码
Feb 05 Javascript
微信小程序实现列表页的点赞和取消点赞功能
Nov 02 Javascript
使用vue-cli3新建一个项目并写好基本配置(推荐)
Apr 24 Javascript
微信小程序基础教程之echart的使用
Jun 01 Javascript
cypress测试本地web应用
Jun 01 Javascript
基本jquery的控制tabs打开的数量的代码
Oct 17 #Javascript
Javascript表达式中连续的 &amp;&amp; 和 || 之赋值区别
Oct 17 #Javascript
Javascript读取cookie函数代码
Oct 16 #Javascript
JavaScript 拾碎[三] 使用className属性
Oct 16 #Javascript
javascript使用eval或者new Function进行语法检查
Oct 16 #Javascript
自己整理的一个javascript日期处理函数
Oct 16 #Javascript
理解Javascript_10_对象模型
Oct 16 #Javascript
You might like
PHP全概率运算函数(优化版) Webgame开发必备
2011/07/04 PHP
PHP面向对象学习笔记之一 基础概念
2012/10/06 PHP
php实现无限级分类
2014/12/24 PHP
PHP实现的简易版图片相似度比较
2015/01/07 PHP
PHP中类属性与类静态变量的访问方法示例
2016/07/13 PHP
基于ThinkPHP5.0实现图片上传插件
2017/09/25 PHP
PHP swoole和redis异步任务实现方法分析
2019/08/12 PHP
php慢查询日志和错误日志使用详解
2021/02/27 PHP
js中将HTMLCollection/NodeList/伪数组转换成数组的代码
2011/07/31 Javascript
Node.js中AES加密和其它语言不一致问题解决办法
2014/03/10 Javascript
jQuery实现企业网站横幅焦点图切换功能实例
2015/04/30 Javascript
jQuery绑定事件监听bind和移除事件监听unbind用法实例详解
2016/01/19 Javascript
AngularJS基于ngInfiniteScroll实现下拉滚动加载的方法
2016/12/14 Javascript
泛谈JS逻辑判断选择器 || &amp;&amp;
2019/05/24 Javascript
CKeditor富文本编辑器使用技巧之添加自定义插件的方法
2019/06/14 Javascript
JavaScript动态添加数据到表单并提交的几种方式
2019/06/26 Javascript
[01:32]寻找你心中的那团火 DOTA2 TI9火焰传递活动今日开启
2019/05/16 DOTA
[01:01:01]完美世界DOTA2联赛循环赛 GXR vs FTD BO2第一场 10.29
2020/10/29 DOTA
Python基于DES算法加密解密实例
2015/06/03 Python
python发送邮件功能实现代码
2016/07/15 Python
PyTorch学习笔记之回归实战
2018/05/28 Python
Python Numpy库安装与基本操作示例
2019/01/08 Python
对python读取CT医学图像的实例详解
2019/01/24 Python
python爬取酷狗音乐排行榜
2019/02/20 Python
详解Python中pyautogui库的最全使用方法
2020/04/01 Python
pycharm实现print输出保存到txt文件
2020/06/01 Python
python交互模式基础知识点学习
2020/06/18 Python
python3 通过 pybind11 使用Eigen加速代码的步骤详解
2020/12/07 Python
CSS3的RGBA中关于整数和百分比值的转换
2015/08/04 HTML / CSS
CSS3 3D酷炫立方体变换动画的实现
2019/03/26 HTML / CSS
端口镜像是怎么实现的
2014/03/25 面试题
购房意向书范本
2014/04/01 职场文书
有限责任公司股东合作协议书
2014/12/02 职场文书
服务明星事迹材料
2014/12/29 职场文书
redis requires ruby version2.2.2的解决方案
2021/07/15 Redis
Nginx 匹配方式
2022/05/15 Servers