Easy Validate简易表单验证
来源:互联网 发布:断开的网络驱动器 编辑:程序博客网 时间:2024/06/05 03:22
在做项目的时候有许多表单需要验证,而这些验证只是一些简易的验证,类似必填,格式之类,为此,有必要整理一个简易通用且容易扩展的表单验证方法。
以下方法思路为:
为需要验证的输入项添加两个自定义属性作为判断的依据以及需要执行的验证
validate="这里输入验证方法,多种验证以分号隔开"
msg="这里输入验证不合格时提示的信息,与validate一一对应,如果信息数少于验证方法数量,则后面的验证不合格时将显示最后一条提示信息"
验证方法可自行扩展,形如:
var rules = {
isFilled:function(validate里提供的参数,可有可无){returnfunction(由后面程序中传递进来的参数$value){return$value.replace(//s/g,"").length>0&&$value!=validate里提供的参数}}
}
使用如下:
<input type="text" validate="isFilled" msg="本项目必须填写!">
代码如下:
<script type="text/javascript">
var nameSpace = {
checkForm:function(dForm){
if(!dForm) return false;
var rules = {
isFilled:function(s){return function($value){return $value.replace(//s/g,"").length>0&&$value!=s}},
isNaN:function(){return function($value){return (!$value)?true:isNaN($value)}},
isNumber:function(){return function($value){return (!$value)?true:!isNaN($value)}},
isInt:function(){return function($value){return (!$value)?true:parseInt($value)==$value}},
isEmail:function(){return function($value){return (!$value)?true:/^(?:/w/.?)*/w+@(?:/w/.?)+/w+$/i.test($value)}},
isEmailList:function(){return function($value){return(!$value)?true:/^(?!;)(?:(?:;|^)([^@.;])+@[^.@;]+(?:/.[^.@;]+)+)+$/i.test($value)}},
fileType:function(list){return function($value){var r = newRegExp('/.(?:'+list+')$','i');return (!$value)?true:r.test($value)}},
moreThan:function(n){return function($value){return (!$value)?true:$value>n}},
lessThan:function(n){return function($value){return (!$value)?true:$value<n}},
equalTo:function(n){return function($value){return (!$value)?true:$value==n}},
maxLength:function(n){return function($value){return (!$value)?true:!($value.length>n)}},
minLength:function(n){return function($value){return (!$value)?true:!($value.length<n)}}
}
var chkInput = function(dObj){
for(var i=0,l=dObj.length;i<l;i++){
var dT = dObj[i];
var vr = dT.getAttribute('validate');//validate property
var vm = dT.getAttribute('msg');//msg property
var $value = dT.value;//value
if(vr){
vr = vr.split(';'),vm = vm.split(';');
for(var n=0;n<vr.length;n++){
var avr = vr[n].match(/^(/w+)/(([^/)]*)/)$/i);//match the validate string look like 'fooName(xxx)'
var avrName = avr?avr[1]:vr[n];//fooName
var avrArgs = avr?avr[2]:null;//xxx
var msg = vm[n]?vm[n]:vm[vm.length-1];//alert message
var EVR = (rules[avrName])?rules[avrName](avrArgs)($value):false;
if(!EVR){
alert(msg);
dT.focus();
return false;
}
}
}
}
return true;
}
return chkInput(dForm.elements);
}
}
</script>
在线演示,请参见 http://www.v-ec.com/jslib
【easy Validate】 部分!
以下方法思路为:
为需要验证的输入项添加两个自定义属性作为判断的依据以及需要执行的验证
validate="这里输入验证方法,多种验证以分号隔开"
msg="这里输入验证不合格时提示的信息,与validate一一对应,如果信息数少于验证方法数量,则后面的验证不合格时将显示最后一条提示信息"
验证方法可自行扩展,形如:
var rules = {
isFilled:function(validate里提供的参数,可有可无){returnfunction(由后面程序中传递进来的参数$value){return$value.replace(//s/g,"").length>0&&$value!=validate里提供的参数}}
}
使用如下:
<input type="text" validate="isFilled" msg="本项目必须填写!">
代码如下:
<script type="text/javascript">
var nameSpace = {
checkForm:function(dForm){
if(!dForm) return false;
var rules = {
isFilled:function(s){return function($value){return $value.replace(//s/g,"").length>0&&$value!=s}},
isNaN:function(){return function($value){return (!$value)?true:isNaN($value)}},
isNumber:function(){return function($value){return (!$value)?true:!isNaN($value)}},
isInt:function(){return function($value){return (!$value)?true:parseInt($value)==$value}},
isEmail:function(){return function($value){return (!$value)?true:/^(?:/w/.?)*/w+@(?:/w/.?)+/w+$/i.test($value)}},
isEmailList:function(){return function($value){return(!$value)?true:/^(?!;)(?:(?:;|^)([^@.;])+@[^.@;]+(?:/.[^.@;]+)+)+$/i.test($value)}},
fileType:function(list){return function($value){var r = newRegExp('/.(?:'+list+')$','i');return (!$value)?true:r.test($value)}},
moreThan:function(n){return function($value){return (!$value)?true:$value>n}},
lessThan:function(n){return function($value){return (!$value)?true:$value<n}},
equalTo:function(n){return function($value){return (!$value)?true:$value==n}},
maxLength:function(n){return function($value){return (!$value)?true:!($value.length>n)}},
minLength:function(n){return function($value){return (!$value)?true:!($value.length<n)}}
}
var chkInput = function(dObj){
for(var i=0,l=dObj.length;i<l;i++){
var dT = dObj[i];
var vr = dT.getAttribute('validate');//validate property
var vm = dT.getAttribute('msg');//msg property
var $value = dT.value;//value
if(vr){
vr = vr.split(';'),vm = vm.split(';');
for(var n=0;n<vr.length;n++){
var avr = vr[n].match(/^(/w+)/(([^/)]*)/)$/i);//match the validate string look like 'fooName(xxx)'
var avrName = avr?avr[1]:vr[n];//fooName
var avrArgs = avr?avr[2]:null;//xxx
var msg = vm[n]?vm[n]:vm[vm.length-1];//alert message
var EVR = (rules[avrName])?rules[avrName](avrArgs)($value):false;
if(!EVR){
alert(msg);
dT.focus();
return false;
}
}
}
}
return true;
}
return chkInput(dForm.elements);
}
}
</script>
在线演示,请参见 http://www.v-ec.com/jslib
【easy Validate】 部分!
- Easy Validate简易表单验证
- validate表单验证插件
- jQuery validate 表单验证
- jquery validate 表单验证
- jquery validate 表单验证
- jQuery validate验证表单
- jquery validate 表单验证
- 表单输入验证-validate
- jQuery Validate 表单验证
- jquery-validate验证表单
- Jquery validate表单验证
- jQuery Validate 表单验证
- jQuery-validate 表单验证
- 使用validate验证表单
- jQuery.validate表单验证
- 表单验证validate
- jQuery Validate 表单验证
- validate.js表单验证
- 写带ScrollBar的控件注意点
- js浮动固定层(对联飘浮广告,随滚动条浮动)
- $.ajax方法(传递json数据)
- 无题
- 网络化应用平台构建及担忧
- Easy Validate简易表单验证
- 收缩sql数据库日志
- 雅虎的真正敌人是衰退性周期
- vi set命令集
- ANSI C中取得结构体字段偏移量的常用方法
- News Digest [11.19]
- 理解驱动程序中的ioctl
- 留言板 用字典检测非法内容并且禁止IP 带详细介绍
- 最近想用用EXT 做项目开发