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 相关文章推荐
给moz-firefox下添加IE方法和属性
Apr 10 Javascript
修改js Calendar日历控件 兼容IE9/谷歌/火狐
Jan 04 Javascript
NODE.JS加密模块CRYPTO常用方法介绍
Jun 05 Javascript
jQuery中delegate()方法用法实例
Jan 19 Javascript
html的DOM中Event对象onblur事件用法实例
Jan 21 Javascript
JavaScript对象属性检查、增加、删除、访问操作实例
Jul 08 Javascript
探索Vue高阶组件的使用
Jan 08 Javascript
Vue2.0 给Tab标签页和页面切换过渡添加样式的方法
Mar 13 Javascript
Django+Vue实现WebSocket连接的示例代码
May 28 Javascript
解决vue组件props传值对象获取不到的问题
Jun 06 Javascript
JS前端知识点offset,scroll,client,冒泡,事件对象的应用整理总结
Jun 27 Javascript
jQuery 隐藏/显示效果函数用法实例分析
May 20 jQuery
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
PHP中的加密功能
2006/10/09 PHP
PHP字符串的连接的简单实例
2013/12/30 PHP
thinkphp3.2.2前后台公用类架构问题分析
2014/11/25 PHP
IE8 引入跨站数据获取功能说明
2008/07/22 Javascript
JS 继承实例分析
2008/11/04 Javascript
快速排序 php与javascript的不同之处
2011/02/22 Javascript
JS+CSS模拟可以无刷新显示内容的留言板实例
2015/03/03 Javascript
使用JQuery实现智能表单验证功能
2016/03/08 Javascript
nodejs简单实现操作arduino
2016/09/25 NodeJs
javascript正则表达式模糊匹配IP地址功能示例
2017/01/06 Javascript
Angular4 中内置指令的基本用法
2017/07/31 Javascript
Vue Router history模式的配置方法及其原理
2019/05/30 Javascript
Moment.js实现多个同时倒计时
2019/08/26 Javascript
Vue强制组件重新渲染的方法讨论
2020/02/03 Javascript
深入解析微信小程序开发中遇到的几个小问题
2020/07/11 Javascript
javascript实现移动端上传图片功能
2020/08/18 Javascript
vue 表单输入框不支持focus及blur事件的解决方案
2020/11/17 Vue.js
[01:11:21]DOTA2-DPC中国联赛 正赛 VG vs Elephant BO3 第一场 3月6日
2021/03/11 DOTA
Python实现桶排序与快速排序算法结合应用示例
2017/11/22 Python
解决pycharm 误删掉项目文件的处理方法
2018/10/22 Python
Python实现DDos攻击实例详解
2019/02/02 Python
Python FFT合成波形的实例
2019/12/04 Python
python爬虫实现获取下一页代码
2020/03/13 Python
Python Pandas数据分析工具用法实例
2020/11/05 Python
Chemist Warehouse中文网:澳洲连锁大药房
2021/02/05 全球购物
物理教育专业毕业生推荐信
2013/11/03 职场文书
公司门卫岗位职责
2014/03/15 职场文书
《夹竹桃》教学反思
2014/04/20 职场文书
查摆剖析材料范文
2014/09/30 职场文书
2014年前台接待工作总结
2014/12/05 职场文书
教师节班会开场白
2015/06/01 职场文书
小学生红领巾广播稿
2015/08/19 职场文书
《红领巾真好》教学反思
2016/02/16 职场文书
JavaGUI模仿QQ聊天功能完整版
2021/07/04 Java/Android
python疲劳驾驶困倦低头检测功能的实现
2022/04/04 Python
Mysql查询时间区间日期列表,不会由于数据表数据影响
2022/04/19 MySQL