jquery validate 自定义验证方法介绍 日期验证
jquery validate有很多验证规则,但是更多的时候,需要根据特定的情况进行自定义验证规则。
这里就来聊一聊jquery validate的自定义验证。
jquery validate有一个方法,可以让用户来自定义验证规则。
案例一:
. 代码如下:
//自定义验证
$.validator.addmethod("ispositive",function(value,element){
var score = /^[0-9]*$/;
return this.optional(element) || (score.test(value));
},"<font color='#e47068'>请输入大于0的数字</font>");
通过addmethod用户可以自定义自己的验证规则
这个方法有三个参数,第一个参数表示验证规则名称,这里是ispositive,表示是否为正数。
第二个参数是真正的验证主体,它是一个函数,函数的第一个value表示调用这个验证规则的表单的值,第二个element可以用来判断是否为空,为空的时候,就不调用这个验证规则了。
第三个参数是返回的错误提示。
具体如何使用呢?
其实跟jquery validate固有的验证规则使用是一样的。
. 代码如下:
<tr bgcolor="#f7f7f7" height="43" align="right">
<td class="font14_s pdr_12 grey_70">总分:</td>
<td class="font14_s pl40" align="left"><input type="text" id="fullscore" name="fullscore" style=" margin-left: 10px; margin-right: 2px;" value="<!--{$aexams.fullscore}-->" class="required number ispositive input_233" /></td>
</tr>
如上所示,加粗的地方就是使用的方法,一共用了三个验证规则,一个是必须,一个是数字,一个是自定义验证规则。
效果图如下:
案例二:
表单提交时,经常会需要对日期进行验证,比如结束时间必须大于开始时间。
这个时候可以通过jquery validate 自定义一个验证方法,进行验证。
方法如下:
. 代码如下:
$.validator.addmethod("comparedate",function(value,element){
var assigntime = $("#assigntime").val();
var deadlinetime = $("#deadlinetime").val();
var reg = new regexp('-','g');
assigntime = assigntime.replace(reg,'/');//正则替换
deadlinetime = deadlinetime.replace(reg,'/');
assigntime = new date(parseint(date.parse(assigntime),10));
deadlinetime = new date(parseint(date.parse(deadlinetime),10));
if(assigntime>deadlinetime){
return false;
}else{
return true;
}
},"<font color='#e47068'>结束日期必须大于开始日期</font>");
上述代码红色部分是对时间字符串进行处理,处理成2013/12/12 08:09:00这种标准格式,
在处理的时候要用到replace的方法,这个方法最后结合正则表达式进行使用,也就是第一行的reg对象。
替换完了之后,如果比较时间呢?要进行三个处理,
1.将标准时间转化为时间戳通过date.parse()方法来处理。
2.将时间戳转化为整数,确保万一,通过parseint("",10)来处理。
3.将时间戳转为日期对象new date()。
转为对象之后,就能够比较时间大小了,直接判断,如果结束时间小于开始时间,就进行错误提示。
这个时候comparedate就可以像其他的jquery validate验证规则一样验证了。
案例三:ajax验证
去验证用户名是否存在,这个也会经常用到。
. 代码如下:
$.validator.addmethod("checkuserexist",function(value,element){
var user = value;
$.ajax({
type:"post",
async:false,
nbsp; url:"/default/index/ajax/do/ajaxcheckuser",
data:"nick="+user,
success:function(response){
if(response){
res = false;
}else{
res = true;
}
}
});
return res;
},"<font color='#e47068'>用户名已存在</font>");
后台验证代码:
. 代码如下:
case 'ajaxcheckuser':
$nick = trim($this->_getparam('nick'));
if(isset($nick)){
$where['lx_user.nick = ?'] = array('type'=>1,'val'=>$nick);
$auser = $daouser->getuser($where);
if(count($auser)>=1){
echo true;
}else{
echo false;
}
}else{
echo false;
}
break;
如果数据库中存在,就返回true。
推荐阅读
-
jQuery Validate让普通按钮触发表单验证的方法
-
jQuery Validate 无法验证 chosen-select元素的解决方法
-
使用jquery.validate自定义方法教程实现手机号码或者固话至少填写一个的逻辑验证
-
jquery validate 自定义验证方法介绍 日期验证
-
jquery内置验证(validate)使用方法示例(表单验证)
-
jQuery Validate插件自定义验证规则的方法
-
解决jquery validate 验证不通过后验证正确的信息仍残留在label上的方法
-
Web编程入门 2.1 jQuery Validate方法 以及批量验证的修改方法
-
jquery.validate.js addMethod添加自定义方法无法作为class验证规则
-
jquery validate添加自定义验证规则(验证邮箱 邮政编码)