JQuery validate 验证数据是否与数据库中数据重复

几天在添加一个验证用户名是否存在的功能时添加了一个自定义方法
//向jQuery Validator中添加自己的规则
	$.validator.addMethod("checkRepeat",function(value,element,params){
			$
				.ajax({
					type : "post",
					dataType : "json",
					data : {
						userLoginName : name
					},
					async : false,
					cache : false,
					url : "${pageContext.request.contextPath}/users/checkLoginName",
					success : function(data) {
						if(data.success){
						 	 return data.flag;
						}else{
							return true;
						}
					},
					error : function() {
						alertMsg("服务器出错");
					}
				});
	},"登录名已存在");
然后后台已经添加了对应的方法,可是就是一直提示用户名重复,明明没有还是提示用户名重复,然后我试了一下
//向jQuery Validator中添加自己的规则
	$.validator.addMethod("checkRepeat",function(value,element,params){
			return true;
	},"登录名已存在");
直接返回一个布尔值发现可以,然后就吧ajax的验证放到了一个方法中,调用那个方法的时候我意识到了,原来ajax中的return和addMethod中的return返回的值给的层面不一样,于是便有了
//向jQuery Validator中添加自己的规则
	$.validator.addMethod("checkRepeat",function(value,element,params){
			return checkLoginName(value);
	},"登录名已存在");
	/**
	*检测用户名是否重复方法
	*/
	function checkLoginName(name){
		var flagTemp = false;
		$
				.ajax({
					type : "post",
					dataType : "json",
					data : {
						userLoginName : name
					},
					async : false,
					cache : false,
					url : "${pageContext.request.contextPath}/users/checkLoginName",
					success : function(data) {
						if(data.success){
						 	flagTemp = data.flag;
						}else{
							flagTemp = true;
						}
					},
					error : function() {
						alertMsg("服务器出错");
					}
				});
				return flagTemp;
	}
然后就解决了这个问题,感觉这个问题出现的有点奇怪,记录一下,然后我发现一个问题,希望大牛们指导一下,就是jquery validate我输入一个字符验证一次,导致一个用户名验证就会进行很多的网络请求,很耗费资源,希望可以全部输完之后,统一验证
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值