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全局对象
Nov 26 Javascript
JS函数验证总结(方便js客户端输入验证)
Oct 29 Javascript
日历查询的算法 如何计算某一天是星期几
Dec 12 Javascript
javascript自定义startWith()和endWith()的两种方法
Nov 11 Javascript
jquery中$each()方法的使用指南
Apr 30 Javascript
微信小程序 购物车简单实例
Oct 24 Javascript
node实现简单的反向代理服务器
Jul 26 Javascript
使用JS组件实现带ToolTip验证框的实例代码
Aug 23 Javascript
vue-router之nuxt动态路由设置的两种方法小结
Sep 26 Javascript
vue 函数调用加括号与不加括号的区别
Oct 29 Javascript
JavaScript实现雪花飘落效果
Dec 27 Javascript
Vue过滤器(filter)实现及应用场景详解
Jun 15 Vue.js
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中常量,变量的作用域和生存周期
2013/08/10 PHP
php生成酷炫的四个字符验证码
2016/04/22 PHP
详细解读php的命名空间(二)
2018/02/21 PHP
Thinkphp 5.0实现微信企业付款到零钱
2018/09/30 PHP
PHP添加PNG图片背景透明水印操作类定义与用法示例
2019/03/12 PHP
php设计模式之状态模式实例分析【星际争霸游戏案例】
2020/03/26 PHP
特殊字符、常规符号及其代码对照表
2006/06/26 Javascript
javawscript 三级菜单的实现原理
2009/07/01 Javascript
jQuery让控件左右移动的三种实现方法
2013/09/08 Javascript
JavaScript实现弹出子窗口并传值给父窗口
2014/12/18 Javascript
jQuery实现仿腾讯视频列表分页效果的方法
2015/08/07 Javascript
jquery+json实现分页效果
2016/03/07 Javascript
jQuery实现大图轮播
2017/02/13 Javascript
AngularJS表单提交实例详解
2017/02/18 Javascript
微信小程序开发图片拖拽实例详解
2017/05/05 Javascript
详解vue 组件之间使用eventbus传值
2017/10/25 Javascript
详解.vue文件中style标签的几个标识符
2018/07/17 Javascript
JS实现盒子跟着鼠标移动及键盘方向键控制盒子移动效果示例
2019/01/29 Javascript
简单了解vue中的v-if和v-show的区别
2019/10/08 Javascript
javascript实现鼠标点击生成文字特效
2019/12/24 Javascript
python list使用示例 list中找连续的数字
2014/01/27 Python
python获得一个月有多少天的方法
2015/06/04 Python
python实现简单聊天应用 python群聊和点对点均实现
2017/09/14 Python
利用python批量修改word文件名的方法示例
2017/10/17 Python
Python一行代码实现快速排序的方法
2019/04/30 Python
解决Django后台ManyToManyField显示成Object的问题
2019/08/09 Python
matplotlib之属性组合包(cycler)的使用
2021/02/24 Python
用css3实现当鼠标移进去时当前亮其他变灰效果
2014/04/08 HTML / CSS
自荐信结尾
2013/10/27 职场文书
家庭教育先进个人事迹材料
2014/01/24 职场文书
孝老爱亲模范事迹
2014/01/24 职场文书
致跳远运动员加油稿
2014/02/11 职场文书
优秀大学生自荐信
2014/06/09 职场文书
园林技术专业求职信
2014/07/28 职场文书
商场消防安全责任书
2014/07/29 职场文书
CSS link与@import的区别和用法解析
2023/05/07 HTML / CSS