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代码
Aug 22 Javascript
JavaScript1.6数组新特性介绍以及JQuery的几个工具方法
Dec 06 Javascript
js实现iGoogleDivDrag模块拖动层拖动特效的方法
Mar 04 Javascript
jQuery跨域问题解决方案
Aug 03 Javascript
jQuery代码实现对话框右上角菜单带关闭×
May 03 Javascript
JavaScript正则表达式校验与递归函数实际应用实例解析
Aug 04 Javascript
ionic2屏幕适配实现适配手机、平板等设备的示例代码
Aug 11 Javascript
Vue-cli-webpack搭建斗鱼直播步骤详解
Nov 17 Javascript
Node.js连接Sql Server 2008及数据层封装详解
Aug 27 Javascript
通过javascript实现段落的收缩与展开
Jun 26 Javascript
微信小程序可滑动周日历组件使用详解
Oct 21 Javascript
JS array数组检测方式解析
May 19 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
用PHP制作静态网站的模板框架(四)
2006/10/09 PHP
PHP date函数参数详解
2006/11/27 PHP
PHP中call_user_func_array()函数的用法演示
2012/02/05 PHP
PHP header()函数常用方法总结
2014/04/11 PHP
Laravel中基于Artisan View扩展包创建及删除应用视图文件的方法
2016/10/08 PHP
php使用正则表达式去掉html中的注释方法
2016/11/03 PHP
在 Laravel 项目中使用 webpack-encore的方法
2019/07/21 PHP
javascript 数组排序函数
2009/08/20 Javascript
div移动 输入框不能输入的问题
2009/11/19 Javascript
javascript 正则替换 replace(regExp, function)用法
2010/05/22 Javascript
js 验证密码强弱的小例子
2013/03/21 Javascript
Jquery Ajax解析XML数据(同步及异步调用)简单实例
2014/02/12 Javascript
JQuery解析HTML、JSON和XML实例详解
2014/03/29 Javascript
js实现checkbox全选和反选示例
2014/05/01 Javascript
jquery通过select列表选择框对表格数据进行过滤示例
2014/05/07 Javascript
javascript用函数实现对象的方法
2015/05/14 Javascript
详解javascript中原始数据类型Null和Undefined
2015/12/17 Javascript
EasyUI 结合JS导出Excel文件的实现方法
2016/11/10 Javascript
文件上传的几个示例分享【推荐】
2016/12/16 Javascript
jquery uploadify隐藏上传进度的实现方法
2017/02/06 Javascript
jQuery UI 实例讲解 - 日期选择器(Datepicker)
2017/09/18 jQuery
vue 实现 ios 原生picker 效果及实现思路解析
2017/12/06 Javascript
浅入深出Vue之组件使用
2019/07/11 Javascript
微信小程序实现列表滚动头部吸顶的示例代码
2020/07/12 Javascript
python pandas实现excel转为html格式的方法
2018/10/23 Python
Django 对象关系映射(ORM)源码详解
2019/08/06 Python
django Layui界面点击弹出对话框并请求逻辑生成分页的动态表格实例
2020/05/12 Python
音频处理 windows10下python三方库librosa安装教程
2020/06/20 Python
HTML5 canvas 瀑布流文字效果的示例代码
2018/01/31 HTML / CSS
小学生安全保证书
2014/02/01 职场文书
离婚协议书范文
2015/01/26 职场文书
2015年度信用社工作总结
2015/05/04 职场文书
技能培训通讯稿
2015/07/18 职场文书
会计工作自我鉴定范文
2019/06/21 职场文书
python Polars库的使用简介
2021/04/21 Python
nginx配置指令之server_name的具体使用
2022/08/14 Servers