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 相关文章推荐
javascript 打开页面window.location和window.open的区别
Mar 17 Javascript
jQuery学习笔记之DOM对象和jQuery对象
Dec 22 Javascript
js获取指定的cookie的具体实现
Feb 20 Javascript
node.js中的http.response.addTrailers方法使用说明
Dec 14 Javascript
详解JavaScript的Date对象(制作简易钟表)
Apr 07 Javascript
jQuery mobile转换url地址及获取url中目录部分的方法
Dec 04 Javascript
认识Knockout及如何使用Knockout绑定上下文
Dec 25 Javascript
JavaScript结合HTML DOM实现联动菜单
Apr 05 Javascript
基于Vue的ajax公共方法(详解)
Jan 20 Javascript
Vue单页应用引用单独的样式文件的两种方式
Mar 30 Javascript
一文了解Vue中的nextTick
May 06 Javascript
js实现九宫格布局效果
May 28 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
咖啡豆要不要放冰箱的原因
2021/03/04 冲泡冲煮
PHP7新特性之抽象语法树(AST)带来的变化详解
2018/07/17 PHP
Laravel框架创建路由的方法详解
2019/09/04 PHP
javascript 表单验证常见正则
2009/09/28 Javascript
javascript 去字符串空格终极版(支持utf8)
2009/11/14 Javascript
jquery ajax abort()的使用方法
2010/10/28 Javascript
jquery插件实现鼠标经过图片右侧显示大图的效果(类似淘宝)
2013/02/04 Javascript
如何用javascript计算文本框还能输入多少个字符
2015/07/29 Javascript
利用AJAX实现WordPress中的文章列表及评论的分页功能
2016/05/17 Javascript
详解jquery插件jquery.viewport.js学习使用方法
2017/09/08 jQuery
微信小程序项目总结之点赞 删除列表 分享功能
2018/06/25 Javascript
解决Vue中引入swiper,在数据渲染的时候,发生不滑动的问题
2018/09/27 Javascript
js获取 gif 的帧数的代码实例
2019/09/10 Javascript
微信小程序修改checkbox的样式代码实例
2020/01/21 Javascript
微信小程序实现可长按移动控件
2020/11/01 Javascript
[01:07:20]DOTA2-DPC中国联赛 正赛 Dynasty vs XG BO3 第二场 2月2日
2021/03/11 DOTA
在Python程序中操作MySQL的基本方法
2015/07/29 Python
python3大文件解压和基本操作
2017/12/15 Python
利用Python暴力破解zip文件口令的方法详解
2017/12/21 Python
简单了解python的break、continue、pass
2019/07/08 Python
Python如何基于rsa模块实现非对称加密与解密
2020/01/03 Python
Python动态强类型解释型语言原理解析
2020/03/25 Python
Python必须了解的35个关键词
2020/07/16 Python
详解基于canvas的视频遮罩插件
2018/01/04 HTML / CSS
3种方式实现瀑布流布局小结
2019/09/05 HTML / CSS
日本最大级玩偶手办购物:あみあみ Amiami
2018/04/23 全球购物
美国班级戒指、帽子和礼服、毕业产品、年鉴:Balfour
2018/11/01 全球购物
校园摄影活动策划方案
2014/02/05 职场文书
党的群众路线教育实践活动个人承诺书
2014/05/22 职场文书
医院节能减排方案
2014/06/13 职场文书
广告学专业求职信
2014/06/19 职场文书
员工自我工作评价
2015/03/06 职场文书
幼儿教师师德培训心得体会
2016/01/09 职场文书
CSS中Single Div 绘图技巧的实现
2021/06/18 HTML / CSS
SpringCloud项目如何解决log4j2漏洞
2022/04/10 Java/Android
python数据处理之Pandas类型转换
2022/04/28 Python