jquery.vilidate的运用
vilidate是jquery的一个form表单验证插件非常实用
里面需要注意的就是remote的用法
/*验证*/
$().ready(function() {
$(".form_all").validate({
/*经验证,都未出错则执行*/
submitHandler: function(form) {
},
/*提示信息位置为下面的空div*/
errorPlacement: function(error, element) { //错误信息位置设置方法
error.appendTo( element.parent().next() ); //这里的element是录入数据的对象
},
onkeyup: false,
/*验证规则*/
rules:{
/*验证码*/
validata_number:{
required:true,
number:true,
rangelength:[6,6],
remote : {
url :'?c=register&m=verification_judge',
type:'post',
data:{
send_code : function(){
return $("#validata_number").val();
},
send_code_name : function(){
return $('form').find('.input_name').val();
},
}
}
},
/*账户邮箱手机号*/
// uername:{
// required:true,
// uername:true
// },
/*玩家账号*/
Player_account:{
required:true,
remote:{
url :'?c=register&m=name_judge',
type:'post',
data:{
name : function(){
return $("#Player_account").val();
},
player_account:function(){
return $("#Player_account").attr('name');
}
}
}
},
/* /!*真实姓名*!/
real_name:{
required:true
},
/!*身份证号码*!/
ID_number:{
IDnumber:true
},*/
/*手机号码*/
phone_number:{
required:true,
number:true,
rangelength:[11,11],
phonenumber:true,
remote: {
url :'?c=register&m=name_judge',
type:'post',
data:{
name : function(){
return $("#phone_number").val();
}
}
}
},
/*旧密码*/
old_password:{
required:true,
rangelength:[6,15],
remote:{
url:'?c=register&m=name_judge',
type:'post',
data:{
name:function(){
return $("#uername_email_phone").val();
},
old_password:function(){
return $("#old_password").val();
}
}
}
},
/*密码*/
password:{
required:true,
rangelength:[6,15]
},
/*确认密码*/
Confirm_password:{
required:true,
rangelength:[6,15],
equalTo: ".password"
},
/*邮箱*/
email: {
required: true,
email: true,
remote:{
url:'?c=register&m=name_judge',
type:'post',
data:{
name:function(){
return $("#email").val();
}
}
}
},
/*找回密码 邮箱*/
email_back: {
required: true,
email:true,
remote:{
url:'?c=register&m=name_judge',
type:'post',
data:{
name:function(){
return $("#email_back").val();
}
}
}
},
/*找回密码 手机*/
phone_back:{
required:true,
number:true,
rangelength:[11,11],
phonenumber:true,
remote:{
url:'?c=register&m=name_judge',
type:'post',
data:{
name:function(){
return $("#phone_back").val();
}
}
}
},
/*修改密码*/
uername_email_phone:{
required:true,
remote:{
url:'?c=register&m=name_judge',
type:'post',
data:{
name:function(){
return $("#uername_email_phone").val();
}
}
}
}
},
/*验证失败提示*/
messages:{
validata_number:{
required:"请输入右侧验证码",
number:"请输入数字",
rangelength:"请输入六位验证码",
remote:"验证码错误"
},
uername:{
required:"请输入用户名",
uername:"该用户不存在,请重新输入"
},
/*real_name:{
required:"请输入您的真实姓名"
},*/
Player_account:{
required:"请输入您的账号",
remote:"账号输入不对,请重新输入"
},
/* ID_number:{
IDnumber:"请输入正确的身份证号码"
},*/
phone_number:{
required:"请输入手机号码",
number:"请输入正确的手机号码",
rangelength:"请输入十一位手机号码",
phonenumber:"请输入正确的手机号码",
remote:"此号码已被注册"
},
old_password:{
required: "请输入密码",
minlength: "密码长度在6到15之间"
},
password:{
required: "请输入密码",
minlength: "密码长度在6到15之间"
},
Confirm_password:{
required: "请输入密码",
minlength: "密码长度在6到15之间",
equalTo: "两次密码输入不一致"
},
email:{
required: "请输入邮箱",
email:"请输入一个正确的邮箱",
remote:"此邮箱已经被注册"
},
email_back:{
required: "请输入邮箱账号",
email:"请输入一个正确的邮箱",
remote:"用户名错误,请重新输入"
},
phone_back:{
required:"请输入手机号码",
number:"请输入正确的手机号码",
rangelength:"请输入十一位手机号码",
phonenumber:"请输入正确的手机号码",
remote:"用户名错误,请重新输入"
},
uername_email_phone:{
required:"请输入正确的用户名/邮箱/手机号码",
remote:"输入账号不存在,请重新输入"
},
old_password:{
required: "请输入密码",
minlength: "密码长度在6到15之间",
remote:"密码输入错误,请重新输入"
}
},
});
1.需注意用remote的一个容易发生错误的地方 在发送ajax的时候格式为json jquery remote认证的是字符串 需要触发的时候返回echo "false";return false; 无需触发 返回echo "true";return false;
2.使用了remote之后 submitHandler: function(form) { } 与 remote会相触 解决方法
function doSubmit()
{
var result =$("form").valid(); //判断input是否符合要求
if(result == true){
return true;
}else{
return false;
}
}
$('#submit').click(function(){
var url = $('form').attr('action');
if(doSubmit()){
var data= $('form :input').serialize();
$.ajax({
url:url,
type:'post',
data:data,
dataType:'json',
success:function(data) {
if (data)
{
alert('成功');
} else
{
alert('失败');
}
}
});
}
});
在工作中遇到的一些情况,如果有更好的麻烦也告诉我!
jquery.vilidate的运用的更多相关文章
- Angular杂谈系列1-如何在Angular2中使用jQuery及其插件
jQuery,让我们对dom的操作更加便捷.由于其易用性和可扩展性,jQuer也迅速风靡全球,各种插件也是目不暇接. 我相信很多人并不能直接远离jQuery去做前端,因为它太好用了,我们以前做的东西大 ...
- jQuery UI resizable使用注意事项、实时等比例拉伸及你不知道的技巧
这篇文章总结的是我在使用resizable插件的过程中,遇到的问题及变通应用的奇思妙想. 一.resizable使用注意事项 以下是我在jsfiddle上写的测试demo:http://jsfiddl ...
- Jquery的点击事件,三句代码完成全选事件
先来看一下Js和Jquery的点击事件 举两个简单的例子 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN&q ...
- jQuery实践-网页版2048小游戏
▓▓▓▓▓▓ 大致介绍 看了一个实现网页版2048小游戏的视频,觉得能做出自己以前喜欢玩的小游戏很有意思便自己动手试了试,真正的验证了这句话-不要以为你以为的就是你以为的,看视频时觉得看懂了,会写了, ...
- jquery和Js的区别和基础操作
jqery的语法和js的语法一样,算是把js升级了一下,这两种语法可以一起使用,只不过是用jqery更加方便 一个页面想要使用jqery的话,先要引入一下jqery包,jqery包从网上下一个就可以, ...
- jQuery之ajax实现篇
jQuery的ajax方法非常好用,这么好的东西,你想拥有一个属于自己的ajax么?接下来,我们来自己做一个简单的ajax吧. 实现功能 由于jq中的ajax方法是用了内置的deferred模块,是P ...
- 利用snowfall.jquery.js实现爱心满屏飞
小颖在上一篇一步一步教你用CSS画爱心中已经分享一种画爱心的方法,这次再分享一种方法用css画爱心,并利用snowfall.jquery.js实现爱心满屏飞的效果. 第一步: 利用伪元素before和 ...
- jQuery的61种选择器
The Write Less , Do More ! jQuery选择器 1. #id : 根据给定的ID匹配一个元素 <p id="myId">这是第一个p标签< ...
- jquery.uploadify文件上传组件
1.jquery.uploadify简介 在ASP.NET中上传的控件有很多,比如.NET自带的FileUpload,以及SWFUpload,Uploadify等等,尤其后面两个控件的用户体验比较好, ...
随机推荐
- 简述Hibernate三种开发方式
1.由domain object->mapping->db(官方推荐) 2.由db开始,用工具生成mapping和domain object(使用较多) 3.由映射文件开始
- jQuery原型技术分解
jQuery原型技术分解 起源----原型继承 用户过javascript的都会明白,在javascript脚本中到处都是 函数,函数可以归置代码段,把相对独立的功能封闭在一个函数包中.函数也可以实现 ...
- InnoDB的表类型,逻辑存储结构,物理存储结构
表类型 对比Oracle支持的各种表类型,InnoDB存储引擎表更像是Oracle中的索引组织表(index organized table).在InnoDB存储引擎表中,每张表都有个主键,如果在创建 ...
- ASP.NET Core MVC/WebAPi如何构建路由?
前言 本节我们来讲讲ASP.NET Core中的路由,在讲路由之前我们首先回顾下之前所讲在ASP.NET Core中的模型绑定这其中有一个问题是我在项目当中遇见的,我们下面首先来看看这个问题. 回顾A ...
- line-height系列(二)——对行内元素(文字、图片、兄弟元素)、块级元素设置line-height后的表现
>原创文章,转载请注明来源! 二.对行内元素(文字.图片.兄弟元素).块级元素设置line-height后的表现 对块级元素无效,对行内元素有效.可继承给行内元素. 文字的line-height ...
- 基于UDP协议的socket通信
服务器端: 1.创建DatagramSocket,指定端口号 2.创建DatagramPacket 3.接收客户端发送的数据信息 4.读取数据 客户端: 1.定义发送信息 2.创建DatagramPa ...
- ReentrantLock获取、释放锁的过程
看了篇文章,觉得分析得很透彻,其后总结的很到位,地址:http://www.iteye.com/topic/1083832 把获取与释放操作串在一起在简单看一下: 获取锁的时候将当前线程放入同步队列, ...
- Java多线程基础——Lock类
之前已经说道,JVM提供了synchronized关键字来实现对变量的同步访问以及用wait和notify来实现线程间通信.在jdk1.5以后,JAVA提供了Lock类来实现和synchronized ...
- Ubuntu安装搜狗拼音
p { margin-bottom: 0.25cm; direction: ltr; color: rgb(0, 0, 0); line-height: 120% } p.western { font ...
- 理解Window和WindowManager
Window表示一个窗口的概念,Window是一个抽象类,它的具体实现是PhoneWindow.创建一个Window,需要通过WindowManager即可完成,WindowManager是外界访问W ...