jquery.validate使用攻略

主要分几部分
jquery.validate 基本用法
jquery.validate API说明
jquery.validate 自定义
jquery.validate 常见类型的验证代码

下载地址

jquery.validate插件的文档地址
http://docs.jquery.com/Plugins/Validation

jquery.validate插件的主页
http://bassistance.de/jquery-plugins/jquery-plugin-validation/

jquery.validate插件主页上提供的demo
http://jquery.bassistance.de/validate/demo/

验证规则

下面是默认校验规则,也可以自定义规则

(1)required:true 必输字段

(2)remote:"check.php" 使用ajax方法调用check.php验证输入值

(3)email:true 必须输入正确格式的电子邮件

(4)url:true 必须输入正确格式的网址

(5)date:true 必须输入正确格式的日期

(6)dateISO:true 必须输入正确格式的日期(ISO),例如:2009-06-23,1998/01/22 只验证格式,不验证有效性

(7)number:true 必须输入合法的数字(负数,小数)

(8)digits:true 必须输入整数

(9)creditcard: 必须输入合法的信用卡号

(10)equalTo:"#field" 输入值必须和#field相同

(11)accept: 输入拥有合法后缀名的字符串(上传文件的后缀)

(12)maxlength:5 输入长度最多是5的字符串(汉字算一个字符)

(13)minlength:10 输入长度最小是10的字符串(汉字算一个字符)

(14)rangelength:[5,10] 输入长度必须介于 5 和 10 之间的字符串")(汉字算一个字符)

(15)range:[5,10] 输入值必须介于 5 和 10 之间

(16)max:5 输入值不能大于5

(17)min:10 输入值不能小于10

验证提示

下面是默认的验证提示,官网有简体中文版的验证提示下载,或者通过jQuery.extend(jQuery.validator.messages自定义错误提示信息,可以将网站的验证提示文本统一到一个文件里。

required: "This field is required.",

remote: "Please fix this field.",

email: "Please enter a valid email address.",

url: "Please enter a valid URL.",

date: "Please enter a valid date.",

dateISO: "Please enter a valid date (ISO).",

number: "Please enter a valid number.",

digits: "Please enter only digits",

creditcard: "Please enter a valid credit card
number.",

equalTo: "Please enter the same value again.",

accept: "Please enter a value with a valid
extension.",

maxlength: $.validator.format("Please enter no more
than {0} characters."),

minlength: $.validator.format("Please enter at least
{0} characters."),

rangelength: $.validator.format("Please enter a
value between {0} and {1} characters long."),

range: $.validator.format("Please enter a value
between {0} and {1}."),

max: $.validator.format("Please enter a value less
than or equal to {0}."),

min: $.validator.format("Please enter a value
greater than or equal to {0}.")

使用方式

1:

在控件中使用默认验证规则,例子:

电子邮件(必填)

<input id="email" class="required
email" value="[email protected]" />

2:

可以在控件中自定义验证规则,例子:

自定义(必填,[3,5])

<input id="complex" value="hi"
class="{required:true,minlength:3, maxlength:5,

messages:{required:‘为什么不输入一点文字呢‘,minlength:‘输入的太少了‘,maxlength:‘输入那么多干嘛‘}}" />

3:

通过javascript自定义验证规则,下面的JS自定义了两个规则,password和confirm_password

$().ready(function() {

$("#form2").validate({

rules: {

password: {

required: true,

minlength: 5

},

confirm_password:
{

required: true,

minlength: 5,

equalTo: "#password"

}

},

messages: {

password: {

required: "没有填写密码",

minlength: jQuery.format("密码不能小于{0}个字符")

},

confirm_password: {

required: "没有确认密码",

minlength: "确认密码不能小于{0}个字符",

equalTo: "两次输入密码不一致嘛"

}

}

});

});

required除了设置为true/false之外,还可以使用表达式或者函数,比如

$("#form2").validate({

rules: {

funcvalidate:
{

required:
function() {return $("#password").val()!=""; }

}

},

messages: {

funcvalidate:
{

required:
"有密码的情况下必填"

}

}

});

Html

密码<input id="password" name="password"
type="password" />

确认密码<input id="confirm_password"
name="confirm_password" type="password" />

条件验证<input id="funcvalidate" name="funcvalidate"
value="" />

4:

使用meta自定义验证信息

首先用JS设置meta

$("#form3").validate({ meta:
"validate" });

Html

email<input class="{validate:{required:true,
email:true,

messages:{required:‘输入email地址‘, email:‘你输入的不是有效的邮件地址‘}}}"/>

5:

使用meta可以将验证规则写在自定义的标签内,比如validate

JS设置meta

$().ready(function() {

$.metadata.setType("attr", "validate");

$("#form1").validate();

});

Html

Email

<input id="email" name="email"

validate="{required:true, email:true,
messages:{required:‘输入email地址‘, email:‘你输入的不是有效的邮件地址‘}}" />

6:

自定义验证规则

对于复杂的验证,可以通过jQuery.validator.addMethod添加自定义的验证规则

官网提供的additional-methods.js里包含一些常用的验证方式,比如lettersonly,ziprange,nowhitespace等

例子

// 字符验证

jQuery.validator.addMethod("userName",
function(value, element) {

return
this.optional(element) || /^[\u0391-\uFFE5\w]+$/.test(value);

}, "用户名只能包括中文字、英文字母、数字和下划线");

//然后就可以使用这个规则了

$("#form1").validate({

// 验证规则

rules: {

userName: {

required: true,

userName: true,

rangelength: [5,10]

}

},

/* 设置错误信息 */

messages: {

userName: {

required: "请填写用户名",

rangelength: "用户名必须在5-10个字符之间"

}

},

});

7:

radio、checkbox、select的验证方式类似

radio的验证

性别

<span>

男<input type="radio"
id="gender_male" value="m" name="gender"
class="{required:true}"/><br />

女<input type="radio"
id="gender_female" value="f" name="gender" />

</span>

checkbox的验证

最少选择两项

<span>

选项1<input type="checkbox"
id="check_1" value="1" name="checkGroup"

class="{required:true,minlength:2,
messages:{required:‘必须选择‘,minlength:‘至少选择2项‘}}" /><br />

选项2<input type="checkbox"
id="check_2" value="2" name="checkGroup"
/><br />

选项3<input type="checkbox"
id="check_3" value="3" name="checkGroup"
/><br />

</span>

select的验证

下拉框

<span>

<select
id="selectbox" name="selectbox" class="{required:true}">

<option
value=""></option>

<option
value="1">1</option>

<option
value="2">2</option>

<option
value="3">3</option>

</select>

</span>

8:

Ajax验证

用remote可以进行Ajax验证

remote: {

url: "url",      //url地址

type:
"post",          
//发送方式

dataType:
"json",       //数据格式     data:
{                
//要传递的数据

username:
function() {

return
$("#username").val();

}}

}

Plugin methods

Name    Type

validate( options )    Returns:
Validator

验证所选的FORM

valid( )       Returns:
Boolean

检查是否验证通过

rules( )       Returns:
Options

返回元素的验证规则

rules( "add", rules )  Returns: Options

增加验证规则

rules( "remove", rules )       Returns: Options

删除验证规则

removeAttrs( attributes )      Returns:
Options

删除特殊属性并且返回他们

Custom selectors

Name    Type

:blank  Returns:
Array <Element >

没有值的筛选器

:filled Returns:
Array <Element >

有值的筛选器

:unchecked     Returns:
Array <Element >

没选择的元素的筛选器

Utilities

Name    Type

jQuery.format( template, argument , argumentN... )   Returns: String

用参数代替模板中的 {n}。

Validator

validate方法返回一个Validator对象, 它有很多方法, 让你能使用引发校验程序或者改变form的内容.

下面只是列出常用的.

form( ) Returns:
Boolean

验证form返回成功还是失败

element( element )     Returns:
Boolean

验证单个元素是成功还是失败

resetForm( )   Returns:
undefined

把前面验证的FORM恢复到验证前原来的状态

showErrors( errors )   Returns:
undefined

显示特定的错误信息

built-in Validation methods

Name    Type

setDefaults( defaults )        Returns:
undefined

改变默认的设置

addMethod( name, method, message )    Returns: undefined

添加一个新的验证方法. 必须包括名字,一个JAVASCRIPT方法和一个默认的信息

addClassRules( name, rules )   Returns: undefined

增加组合验证类型

addClassRules( rules ) Returns:
undefined

增加组合验证类型

built-in Validation methods

Name    Type

required( )    Returns:
Boolean

必填验证元素

required( dependency-expression )     Returns: Boolean

必填元素依赖于表达式的结果.

required( dependency-callback )       Returns: Boolean

必填元素依赖于回调函数的结果.

remote( url )  Returns:
Boolean

请求远程校验。url通常是一个远程调用方法

minlength( length )    Returns:
Boolean

设置最小长度

maxlength( length )    Returns:
Boolean

设置最大长度

rangelength( range )   Returns:
Boolean

设置一个长度范围[min,max]

min( value )   Returns:
Boolean

设置最小值.

max( value )   Returns:
Boolean

设置最大值.

range( range ) Returns:
Boolean

设置值的范围

email( )       Returns:
Boolean

验证电子邮箱格式

url( )  Returns:
Boolean

验证连接格式

date( ) Returns:
Boolean

验证日期格式(类似30/30/2008的格式,不验证日期准确性只验证格式)

dateISO( )     Returns:
Boolean

研制ISO类型的日期格式

dateDE( )      Returns:
Boolean

验证德式的日期格式(29.04.1994 or 1.1.2006)

number( )      Returns:
Boolean

验证十进制数字(包括小数的)

numberDE( )    Returns:
Boolean

Makes the element require a decimal number with german
format.

digits( )      Returns:
Boolean

验证整数

creditcard( )  Returns:
Boolean

验证信用卡号

accept( extension )    Returns:
Boolean

验证相同后缀名的字符串

equalTo( other )       Returns:
Boolean

验证两个输入框的内容是否相同

自定义jquery-validate的验证行为

1: 自定义表单提交

设置submitHandler来自定义表单提交动作

$(".selector").validate({

submitHandler:
function(form) { alert("验证通过"); }

});

如果需要提交表单,可以调用

form.submit(); 或者$(form).ajaxSubmit();

2: 调试模式

将debug设置为true,表单不会提交,只进行检查,方便调试

$(".selector").validate({

debug: true

})

3: 设置validate的默认值

使用setDefaults可以设置validate的默认值,比如默认所有表单验证都是在debug模式下进行

$.validator.setDefaults({

debug: true

})

4: 某些元素不验证

设置ignore属性可以忽略某些元素不验证

$(".selector").validate({

ignore:
"ignore"

})

5: 验证时机

jquery.validate可以很方便的设置在什么时候触发验证动作

onsubmit: 提交时是否验证

$(".selector").validate({

onsubmit: false

})

onfocusout: 失去焦点时验证(checkboxes/radio除外)

$(".selector").validate({

onfocusout:
false

})

onkeyup: 在keyup时验证

$(".selector").validate({

onkeyup: false

})

onclick: 在checkboxes、radio点击时验证.

$(".selector").validate({

onclick: false

})

6: 重写验证规则和验证提示信息

//重写max的的验证提示信息

$.validator.messages.max = jQuery.format("Your
totals musn‘t exceed {0}!");

//重写equal方法

$.validator.methods.equal = function(value, element,
param) {

return value
== param;

};

7: focusInvalid 是否把焦点聚焦在最后一个动作或者最近的一次出错上

$(".selector").validate({

focusInvalid:
false

})

8: focusCleanup

如果该属性设置为True, 那么控件获得焦点时,移除出错的class定义,隐藏错误信息,避免和 focusInvalid.一起用。

$(".selector").validate({

focusCleanup:
true

})

9: meta

设置meta来封装验证规则

$(".selector").validate({

meta:
"validate",

})

<script
type="text/javascript"></script>

自定义错误消息的显示方式

默认情况下,验证提示信息用label元素来显示, 并且会添加css class, 通过css可以很方便设置出错控件以及错误信息的显示方式。

/* 输入控件验证出错*/

form  input.error {
border:solid 1px red;}

/* 验证错误提示信息*/

form label.error{width: 200px;margin-left: 10px; color:
Red;}

如果想自定义显示方式,可以修改jquery.validate的默认显示方式

默认用label显示错误消息,可以通过errorElement属性来修改

errorElement: 错误消息的html标签

$(".selector").validate

errorElement:
"em"

})

可以在出错信息外用其他的元素包装一层。

wrapper: 错误消息的外层封装html标签

$(".selector").validate({

wrapper:
"li"

})

验证出错的css class默认是error,通过errorClass可以修改

errorClass: 验证出错时使用的css class

$(".selector").validate({

errorClass:
"invalid"

})

还自定义验证成功时的动作

success: 如果值是字符串,会当做一个css类,如果是一个函数,则执行该函数

$(".selector").validate({

success:
"valid"

})

或者

success: function(label) {

label.html("
").addClass("checked");

}

还可以把错误消息统一到一个容器显示

errorLabelContainer: 将错误消息统一到一个容器显示

$("#myform").validate({

errorLabelContainer: "#messageBox"

})

默认情况下,错误消息是放在验证元素后面的,可以自定义错误消息的显示位置

$(".selector").validate({

errorPlacement:
function(error, element) {

error.appendTo( element.parent("td").next("td") );

}

})

更进一步可以定义一个组,把几个地方的出错信息统一放在一个地方,用error Placement控制把出错信息放在哪里

groups:定义一个组

$(".selector").validate({

groups: {

username:
"fname lname"

},

errorPlacement:
function(error, element) {

if
(element.attr("name") == "fname" ||
element.attr("name") == "lname" )

error.insertAfter("#lastname");

else

error.insertAfter(element);

}

})

高亮显示

highlight: 高亮显示,默认是添加errorClass

unhighlight: 和highlight对应,反高亮显示

$(".selector").validate({

highlight:
function(element, errorClass) {

$(element).addClass(errorClass);

$(element.form).find("label[for="
+ element.id + "]").addClass(errorClass);

},

unhighlight:
function(element, errorClass) {

$(element).removeClass(errorClass);

$(element.form).find("label[for=" + element.id +
"]").removeClass(errorClass);

}

});

或者可以完全自定义错误显示

showErrors: 得到错误的显示句柄

$(".selector").validate({

showErrors:
function(errorMap, errorList) {

$("#summary").html("Your
form contains " + this.numberOfInvalids()

+
" errors, see details below.");

this.defaultShowErrors();

}

})

<script
type="text/javascript"></script>

// 手机号码验证

jQuery.validator.addMethod("mobile",
function(value, element) {

var length = value.length;

var mobile = 
/^(((13[0-9]{1})|(15[0-9]{1}))+\d{8})$/

return this.optional(element) ||
(length == 11 && mobile.test(value));

}, "手机号码格式错误");

// 电话号码验证

jQuery.validator.addMethod("phone",
function(value, element) {

var tel =
/^(0[0-9]{2,3}\-)?([2-9][0-9]{6,7})+(\-[0-9]{1,4})?$/;

return this.optional(element) ||
(tel.test(value));

}, "电话号码格式错误");

// 邮政编码验证

jQuery.validator.addMethod("zipCode",
function(value, element) {

var tel = /^[0-9]{6}$/;

return this.optional(element) ||
(tel.test(value));

}, "邮政编码格式错误");

// QQ号码验证

jQuery.validator.addMethod("qq", function(value,
element) {

var tel = /^[1-9]\d{4,9}$/;

return this.optional(element) ||
(tel.test(value));

}, "qq号码格式错误");

// IP地址验证

jQuery.validator.addMethod("ip",
function(value, element) {

var ip =
/^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/;

return this.optional(element) ||
(ip.test(value) && (RegExp.$1 < 256 && RegExp.$2 < 256
&& RegExp.$3 < 256 && RegExp.$4 < 256));

}, "Ip地址格式错误");

// 字母和数字的验证

jQuery.validator.addMethod("chrnum",
function(value, element) {

var chrnum = /^([a-zA-Z0-9]+)$/;

return this.optional(element) ||
(chrnum.test(value));

}, "只能输入数字和字母(字符A-Z, a-z, 0-9)");

// 中文的验证

jQuery.validator.addMethod("chinese",
function(value, element) {

var chinese = /^[\u4e00-\u9fa5]+$/;

return this.optional(element) ||
(chinese.test(value));

}, "只能输入中文");

// 下拉框验证

$.validator.addMethod("selectNone",
function(value, element) {

return value == "请选择";

}, "必须选择一项");

// 字节长度验证

jQuery.validator.addMethod("byteRangeLength",
function(value, element, param) {

var length = value.length;

for (var i = 0; i < value.length;
i++) {

if
(value.charCodeAt(i) > 127) {

length++;

}

}

return this.optional(element) ||
(length >= param[0] && length <= param[1]);

}, $.validator.format("请确保输入的值在{0}-{1}个字节之间(一个中文字算2个字节)"));

jquery.validate使用攻略

时间: 2024-11-08 04:22:13

jquery.validate使用攻略的相关文章

jquery.validate使用攻略(表单校验)

目录 jquery.validate使用攻略1 第一章 jquery.validate使用攻略1 第二章 jQuery.validate.js API7 Custom selectors7 Utilities8 Validator8 List of built-in Validation methods9 validate ()的可选项11 debug:进行调试模式11 第三章 自定义jquery-validate的验证行为23 第四章 自定义错误消息的显示方式25 第五章 一些常用的验证脚本2

jquery.validate使用 - 1

jquery.validate使用攻略 好几年不写JS了,资料整理起来比较慢,格式也有点乱 主要分几部分jquery.validate 基本用法jquery.validate API说明jquery.validate 自定义jquery.validate 常见类型的验证代码 下载地址 jquery.validate插件的文档地址http://docs.jquery.com/Plugins/Validation jquery.validate插件的主页http://bassistance.de/j

JQuery攻略(四)事件

jQuery事件处理,鼠标的单击,双击,悬停,键盘按键,文本动画..... 此章节有 1.1被点击的按钮查找 1.2事件的自动触发 1.3点击之后禁用按钮 1.4鼠标事件 1.5焦点事件 1.6CSS的操作 1.7元素创建 1.8动画隐藏和展示 1.9效果 1.10键盘输入控制 1.11防止事件冒泡 小结 1.1被点击的按钮查找 一个页面上有很多按钮,对应不同的功能,一个按钮对应一个事件,说到底就是给每个按钮绑定一个事件. <html xmlns="http://www.w3.org/19

移动端点击事件全攻略,有你知道与不知道的各种坑

看标题的时候你可能会想,点击事件有什么好说的,还写一篇攻略?哈哈,如果你这么想,只能说明你too young to simple. 接触过移动端开发的同学可能都会面临点击事件的第一个问题:click事件的300ms延迟响应.不能立即响应给体验造成了很大的困扰,因此解决这个问题就成为了必然. 这个问题的解决方案就是: zepto.js的tap事件.tap事件可以理解为在移动端的click事件,而zepto.js因为几乎完全复制jQuery的api,因此常常被用在h5的开发上用来取代jquery.

程序员技术练级攻略

以下全文来自http://coolshell.cn/articles/4990.html 前言 你是否觉得自己从学校毕业的时候只做过小玩具一样的程序?走入职场后哪怕没有什么经验也可以把以下这些课外练习走一遍(朋友的抱怨:学校课程总是从理论出发,作业项目都看不出有什么实际作用,不如从工作中的需求出发) 建议: 不要乱买书,不要乱追新技术新名词,基础的东西经过很长时间积累而且还会在未来至少10年通用. 回顾一下历史,看看历史上时间线上技术的发展,你才能明白明天会是什么样. 一定要动手,例子不管多么简

前台页面优化全攻略(三)

经过前两篇文章的实践,你的网站加载速度一定有了非常明显的变化.能把实践跟到这篇文章的人想必一定是极客中的极客.如果你仍对网站的加载速度不满意,可以看看再尝试一下本文中几近疯狂的终极优化方案. 你可以对网站进行快速的优化,但网站日常的节食却很难.也许你已经花了很大的力气去优化你的CSS和JavaScript代码,但是你所做的努力马上又会因为老板或客户期望的新功能而付之东流.所以看来不论是人还是网页,减肥都贵在坚持. 这篇终极减肥方案可能不适合所有的网站,但是我相信它可以引起你对网页大小的重视. 1

cafebabe.cc/navo 我也来写写攻略

=如果还没有点进去过cafebabe.cc/nazo/ 过的话,可以先点进去尝试一下闯关哦~= 目前没有搜到比较全的攻略,相对完整的就是来自知乎(http://www.zhihu.com/question/31231641)上张博韬大神的解答啦.不过他点到为止,有时还是有点捉摸不透.我想把他的答案写得再具体一点.这就是我这篇攻略的重点了.... 不过还是推荐大家自己先尝试闯关,攻略都是折叠起来的,实在想不通了再打开吧.恩,不多说了,点开链接进去吧! level1:点击“此处”链接就好了,没什么好

axios全攻略

随着 vuejs 作者尤雨溪发布消息,不再继续维护vue-resource,并推荐大家使用 axios 开始,axios 被越来越多的人所了解.本来想在网上找找详细攻略,突然发现,axios 的官方文档本身就非常详细!!有这个还要什么自行车!!所以推荐大家学习这种库,最好详细阅读其官方文档.大概翻译了一下 axios 的官方文档,相信大家只要吃透本文再加以实践,axios 就是小意思啦!! 如果您觉得本文对您有帮助,不妨点个赞或关注收藏一下,您的鼓励对我非常重要. axios 简介 axios

Angularjs中UI Router全攻略

摘自:Angularjs中UI Router全攻略 温馨提示:想要了解 angular-ui-router的同学,从上往下读一遍,能带随着coding那就更好了,保证你对angular-ui-router基本全部掌握. 如何引用依赖angular-ui-router angular.module('app',["ui.router"]) .config(function($stateProvider){ $stateProvider.state(stateName, stateCofi