基于jQuery的表单验证插件:jValidate

乐观的橙橙橙汁

乐观的橙橙橙汁

2016-02-19 13:55

下面图老师小编要跟大家分享基于jQuery的表单验证插件:jValidate,简单的过程中其实暗藏玄机,还是要细心学习,喜欢还请记得收藏哦!

网上基于jQuery的表单验证插件已有很多,但是这个轮子我还是继续做一个,因为这个表单验证插件是从我以前的个人JavaScript框架移值过来的(我已慢慢投入jQuery的怀抱),并且它的验证规则书写方式也许会让你眼前一亮。

网上的各类表单验证插件的验证规则都是写在脚本里的,但我的插件的验证规则却是写在表单元素的属性里的。如下面的例子:

input name="name" type="text" id="name" size="30" jvpattern="^.+$" jverrortip="请输入正确的姓名." jvtipid="spt_name" jvmethod="checkname" /
span id="spt_name" class="normaltips" jverrorclass="errortips" jvcorrectclass="correcttips"/span

 注意看上面代码中以jv开头的各种属性名,这些都是表单验证插件需要用的属性值。其中各属性代表的意思请阅读以下表:

1、form表格控件元素可使用的属性

属性名说明 jvpattern用来验证控件值是否正确的正则表达式。(可不定义此属性) jvcompareid需要与当前控件进行值相等比较的其它控件id。(可不定义此属性) jvrequired表明当前控件值是否是必须的,也即是否允许当前控件值为空。如不定义此属性则默认为不可空,如果值为false或0则允许为空。(可不定义此属性) jvmethod

定义需要进行额外验证的方法。(可不定义此属性)

此属性值如果定义,则不需要输写括号,并且函数原型为:

xx function(item){

    //代码

   

    //true表示验证成功,false表示验证失败。

    return true/false;

    //或者带错误消息的返回

    return {result:true/false, message:'错误消息'};

}

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

其中item参数是当前控件对象的jQuery实例。

jvtipid

显示验证提示信息的控件id。(可不定义此属性)

注:如果不定义此属性,并且未定义onerror或oncorrect函数则默认为alert提示

jverrortip当验证失败时要显示的提示信息。(可不定义此属性) jvcorrecttip当验证成功时要显示的提示信息。(可不定义此属性) jvfocuson当验证失败后是否需要将光标移到控件上。(可不定义此属性)

 控件上必须定义:jvpattern、jvmethod、jvcompareid 三者之中的一个或多个,否则插件将不对对应的控件进行验证。

 

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

2、tip提示控件元素可使用的属性:tip提示控件即是某个表单控件jvtipid指定的控件。

属性名说明 jvnormalclass正常情况下显示提示信息时采用的css样式的classname。(可不定义此属性) jvcorrectclass验证成功后显示提示信息时采用的css样式的classname。(可不定义此属性) jverrorclass验证失败后显示提示信息时采用的css样式的classname。(可不定义此属性)

 

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

当控件规则设置好后就可以直接激活调用jValidate,以便当表单进行submit提交前,进行验证检查。

示例: 

$('form').jValidate();

 

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

或者带参数的调用: 

$('form').jValidate({
 blurvalidate : true,
 isbubble : false,
 onerror : function(item,form){
  $.jMessageBox.show('错误', item.attr('jverrortip'));
 }
});

 

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

可设置的参数请阅读下表:

参数名说明 isbubble

是否允许冒泡,也即是否允许逐个检查各控件值,如果值为true,则会逐一检查验证所有已设置验证规则的控件;如果值为false则当有一个控件值验证失败(不符合条件)后,将退出后续控件的检查。默认值为false

注:如果提示信息是以弹出窗口方式显示的,建议将此值设置为false,以免一下子弹出较多提示,引起用户反感。

blurvalidate设置当个个控件失去焦点后是否需要即时检查验证。默认值为false。 emptytip是否允许空提示。也即是当没有提示信息可显示时,是否还允许提示控件改变css类。默认值为false oncorrect

当控件值验证成功时调用处理的方法,如果未定义则采用默认行为。函数原型:

function(item, form){

   //代码

}

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

其中参数item: 表示当前控件的jQuery实例; form : 表示控件所在的表单实例

onerror

当控件值验证失败时调用处理的方法,如果未定义则采用默认行为。函数原型:

function(item, form){

   //代码

}

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

其中参数item: 表示当前控件的jQuery实例; form : 表示控件所在的表单实例

 

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

示例截图:

 

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

源码下载:(压缩包附带jMessageBox示例,关于jMessageBox请参考此文)

/Files/kingthy/jvalidate.zip

展开更多 50%)
分享

猜你喜欢

基于jQuery的表单验证插件:jValidate

Web开发
基于jQuery的表单验证插件:jValidate

jValidate 基于jQuery的表单验证插件

Web开发
jValidate 基于jQuery的表单验证插件

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

Javascript 验证表单插件

Web开发
Javascript 验证表单插件

jquery 最简单易用的表单验证插件

Web开发
jquery 最简单易用的表单验证插件

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

jquery validation插件表单验证的一个例子

Web开发
jquery validation插件表单验证的一个例子

基于JQuery的cookie插件

Web开发
基于JQuery的cookie插件

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

选择TreeView控件的树状数据节点的JS方法(jquery)

选择TreeView控件的树状数据节点的JS方法(jquery)

穿了2个月的睡衣 该换了 - QQ搞笑分组

穿了2个月的睡衣 该换了 - QQ搞笑分组
下拉加载更多内容 ↓