jValidate 基于jQuery的表单验证插件


Posted in Javascript onDecember 12, 2009

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

<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:'错误消息'}; } 其中item参数是当前控件对象的jQuery实例。
jvtipid 显示验证提示信息的控件id。(可不定义此属性) 注:如果不定义此属性,并且未定义onerror或oncorrect函数则默认为alert提示
jverrortip 当验证失败时要显示的提示信息。(可不定义此属性)
jvcorrecttip 当验证成功时要显示的提示信息。(可不定义此属性)
jvfocuson 当验证失败后是否需要将光标移到控件上。(可不定义此属性)

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

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

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

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

示例:

$('form').jValidate();

或者带参数的调用:

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

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

参数名 说明
isbubble 是否允许“冒泡”,也即是否允许逐个检查各控件值,如果值为true,则会逐一检查验证所有已设置验证规则的控件;如果值为false则当有一个控件值验证失败(不符合条件)后,将退出后续控件的检查。默认值为false 注:如果提示信息是以弹出窗口方式显示的,建议将此值设置为false,以免一下子弹出较多提示,引起用户反感。
blurvalidate 设置当个个控件失去焦点后是否需要即时检查验证。默认值为false。
emptytip 是否允许空提示。也即是当没有提示信息可显示时,是否还允许提示控件改变css类。默认值为false
oncorrect 当控件值验证成功时调用处理的方法,如果未定义则采用默认行为。函数原型: function(item, form){ //代码 } 其中参数item: 表示当前控件的jQuery实例; form : 表示控件所在的表单实例
onerror 当控件值验证失败时调用处理的方法,如果未定义则采用默认行为。函数原型: function(item, form){ //代码 } 其中参数item: 表示当前控件的jQuery实例; form : 表示控件所在的表单实例

示例截图:

jValidate 基于jQuery的表单验证插件
源码下载 压缩包附带jMessageBox示例
https://3water.com/jiaoben/23094.html

Javascript 相关文章推荐
把JS与CSS写在同一个文件里的书写方法
Jun 02 Javascript
JS+CSS制作DIV层可(最小化/拖拽/排序)功能实现代码
Feb 25 Javascript
jquery给图片添加鼠标经过时的边框效果
Nov 12 Javascript
通过复制Table生成word和excel的javascript代码
Jan 20 Javascript
jQuery:delegate中select()不起作用的解决方法(实例讲解)
Jan 26 Javascript
jquery学习总结(超级详细)
Sep 04 Javascript
js实现两点之间画线的方法
May 12 Javascript
JavaScript之AOP编程实例
Jul 17 Javascript
jquery+css3实现网页背景花瓣随机飘落特效
Aug 17 Javascript
AngularJS使用ngMessages进行表单验证
Dec 27 Javascript
设计模式中的facade外观模式在JavaScript开发中的运用
May 18 Javascript
require.js 加载过程与使用方法介绍
Oct 30 Javascript
ASP小贴士/ASP Tips javascript tips可以当桌面
Dec 10 #Javascript
Ext.MessageBox工具类简介
Dec 10 #Javascript
模仿JQuery.extend函数扩展自己对象的js代码
Dec 09 #Javascript
js 与或运算符 || &amp;&amp; 妙用
Dec 09 #Javascript
测试你的JS的掌握程度的代码
Dec 09 #Javascript
用javascript获取当页面上鼠标光标位置和触发事件的对象的代码
Dec 09 #Javascript
jMessageBox 基于jQuery的窗口插件
Dec 09 #Javascript
You might like
phpmyadmin 常用选项设置详解版
2010/03/07 PHP
php的一些小问题
2010/07/03 PHP
PHP中引用类型和值类型功能与用法示例
2019/02/26 PHP
列表内容的选择
2006/06/30 Javascript
JQuery复制DOM节点的方法
2015/06/11 Javascript
探讨JavaScript语句的执行过程
2016/01/28 Javascript
JavaScript Date对象详解
2016/03/01 Javascript
js中字符串编码函数escape()、encodeURI()、encodeURIComponent()区别详解
2016/04/01 Javascript
Javascript类型系统之String字符串类型详解
2016/06/21 Javascript
微信小程序开发之数据存储 参数传递 数据缓存
2017/04/13 Javascript
JS实现移动端判断上拉和下滑功能
2017/08/07 Javascript
一个Vue页面的内存泄露分析详解
2018/06/25 Javascript
JavaScript类的继承方法小结【组合继承分析】
2018/07/11 Javascript
为什么说JavaScript预解释是一种毫无节操的机制详析
2018/11/18 Javascript
JS实现前端动态分页码代码实例
2020/06/02 Javascript
Python中read()、readline()和readlines()三者间的区别和用法
2017/07/30 Python
python3.5绘制随机漫步图
2018/08/27 Python
python  Django中的apps.py的目的是什么
2018/10/15 Python
python实现QQ邮箱/163邮箱的邮件发送
2019/01/22 Python
Python中使用pypdf2合并、分割、加密pdf文件的代码详解
2019/05/21 Python
Python Selenium 之数据驱动测试的实现
2019/08/01 Python
Pandas把dataframe或series转换成list的方法
2020/06/14 Python
Python2手动安装更新pip过程实例解析
2020/07/16 Python
python如何导出微信公众号文章方法详解
2020/08/31 Python
CheapTickets香港机票预订网站:CheapTickets.hk
2019/06/26 全球购物
深圳-东方伟业笔试部分
2015/02/11 面试题
Java中采用什么结构来捕获、处理异常?各子句的顺序、功能如何
2013/10/07 面试题
银行类自荐信
2014/02/04 职场文书
个人授权委托书范文
2014/09/21 职场文书
中层领导干部群众路线对照检查材料思想汇报
2014/10/02 职场文书
酒店温馨提示语
2015/07/14 职场文书
致运动员的广播稿
2015/08/19 职场文书
大学学生会主席竞选稿
2015/11/19 职场文书
pandas 操作 Excel操作总结
2021/03/31 Python
简单聊聊TypeScript只读修饰符
2022/04/06 Javascript
java实现web实时消息推送的七种方案
2022/07/23 Java/Android