atitit.表单验证 的dsl 本质跟 easyui ligerui比较
atitit.表单验证的dsl 本质跟 easyui ligerui比较
4. 犯错误消息提示,generic canBeEmpty is good 3
5. Prevent the form to submit when invalid 3
1. DSL 声明验证
<input class="easyui-validatebox" type="text" name="email" required="true" validType="email"></input>
We add a class named easyui-validatebox to input markup so the input markup will be applied the validation according the validType attribute.
Liger
<input ligeruiid="txtName" style="width: 174px;" class="l-text-field" name="txtName" id="txtName" ltype="text" validate="{required:true,minlength:3,maxlength:10}" type="text">
验证规则
验证规则使用required和validType属性来定义, 以下列出的是插件内置的验证规则。
1 email: 正则匹配电子邮件。
2 url: 正则匹配url。
3 length[0,100]: 验证长度范围。
4 remote['http://.../action.do','paramName']: 发送ajax请求来验证,验证有效时返回true。
作者:: 老哇的爪子 Attilax 艾龙, EMAIL:1466519819@qq.com
转载请注明来源: http://blog.csdn.net/attilax
2. 自定义规则
要自定义规则,重载$.fn.validatebox.defaults。你所定义的验证规则必须定义一个验证函数和验证无效时的提示信息。 例如,定义一个验证最小长度的规则:
5 $.extend($.fn.validatebox.defaults.rules, {
6 minLength: {
7 validator: function(value, param){
8 return value.length >= param[0];
9 },
10 message: 'Please enter at least {0} characters.'
11 }
12 });
现在你可以使用最小长度验证规则来定义一个至少要输入5个字符的输入框。
13 <input class="easyui-validatebox" validType="minLength[5]">
14 此处的validType=“minLength[5]”,设置可能无效,可设置为validType="length[3,8]",填入的值在3~8个字符之间
属性
3. 正则表达式验证,可以扩展实现
拓展2
$.extend($.fn.validatebox.defaults.rules,{
idcard : {// 验证身份证
validator : function(value) {
return/^\d{15}(\d{2}[A-Za-z0-9])?$/i.test(value);
},
message : '身份证号码格式不正确'
},
4. 犯错误消息提示,generic canBeEmpty is good
属性
|
名称 |
类型 |
描述 |
默认值 |
|
required(必填) |
boolean(布尔型) |
定义表单域必须填写。 |
false |
|
validType(验证类型) |
string(字符串) |
定义表单域的验证类型,比如:email, url等。 |
null |
|
missingMessage(未填提示) |
string(字符串) |
当表单域未填写时出现的提示信息。 |
This field is required. |
|
invalidMessage(无效提示) |
string(字符串) |
当表单域的内容被验证为无效时出现的提示。 |
null |
Liger::::deft is this field is not be empty ,,jsig haon normall....generic...
5. Prevent the form to submit when invalid
When users click the submit button of form, we should prevent the form to submit if the form is invalid.
15 $('#ff').form({
16 url:'form3_proc.php',
17 onSubmit:function(){
18 return $(this).form('validate');
19 },
20 success:function(data){
21 $.messager.alert('Info', data, 'info');
22 }
23 });
If the form is invalid, a tooltip message will show.
--------liger
$(function ()
{
$.metadata.setType("attr", "validate");
var v = $("form").validate({
debug: true,
errorPlacement: function (lable, element)
{
if (element.hasClass("l-textarea"))
{
element.ligerTip({ content: lable.html(), target: element[0] });
}
else if (element.hasClass("l-text-field"))
{
element.parent().ligerTip({ content: lable.html(), target: element[0] });
}
else
{
lable.appendTo(element.parents("td:first").next("td"));
}
},
success: function (lable)
{
lable.ligerHideTip();
lable.remove();
},
submitHandler: function ()
{
$("form .l-text,.l-textarea").ligerHideTip();
alert("Submitted!")
}
});
$("form").ligerForm();
$(".l-button-test").click(function ()
{
alert(v.element($("#txtName")));
});
});
6. 为空则不验证,不为空则验证,的实现
现在是不适合的,还要自己扩展规则。
但email,url,电话这种很多时候需求都是允许为空的。
重载一下验证规则:
Js代码
24 $.extend($.fn.validatebox.defaults.rules, {
25 email:{
26 validator:function(value,param){
27 if (value){
28 return /^([\w]+)(.[\w]+)*@([\w-]+\.){1,5}([A-Za-z]){2,4}$/.test(value);
29 } else {
30 return true;
31 }
32 },
33 message:'Please enter a valid email address.'
34 },
35 url:{
36 validator:function(value,param){
37 if (value){
38 return /(((https?)|(ftp)):\/\/([\-\w]+\.)+\w{2,3}(\/[%\-\w]+(\.\w{2,})?)*(([\w\-\.\?\\\/+@&#;`~=%!]*)(\.\w{2,})?)*\/?)/i.test(value);
39 } else {
40 return true;
41 }
42 },
43 message:'Please enter a valid URL.'
44 }
45 });
7. 参考
扩展easyui 的表单验证 - 疯狂秀才 - 博客园.htm
easyui 正则表达式验证扩展(包括一些经常用到的正则验证式)_东avaj东_新浪博客.htm
atitit.表单验证 的dsl 本质跟 easyui ligerui比较的更多相关文章
- atittit.表单验证的实现方式以及原理本质以及选型以及自定义兼容easyui dsl规则的表单验证
atittit.表单验证的实现方式以及原理本质以及选型以及自定义兼容easyui dsl规则的表单验证 1. 需求,表单验证需要弹框式,但目前easyui ms绑定死了tooltip式样 1 2. 表 ...
- atittit.表单验证性质的原则和实施,以及选择和定义自己的兼容easyui dsl窗体身份验证规则
atittit.表单验证性质的原则和实施,以及选择和定义自己的兼容easyui dsl规则的表单验证 1. 需求,表单验证须要弹框式,但眼下easyui ms绑定死了tooltip式样 1 2. 表单 ...
- AngularJS系列:表单全解(表单验证,radio必选,三级联动,check绑定,form提交验证)
一.查看$scope -->寻找Form控制变量的位置 Form控制变量 格式:form的name属性.input的name属性.$... formName.inputField.$pristi ...
- python_way day19 HTML-day5 (form表单验证,CSRF,cookie,session,缓存)
python-way day19 1. dJango的form表单验证 2.CSRF 跨站请求伪造 3.cookie,session 4.缓存 一,django表单验证功能 1.django验证基础: ...
- jQuery html5Validate基于HTML5表单验证插件
更新于2016-02-25 前面提到的新版目前线上已经可以访问: http://mp.gtimg.cn/old_mp/assets/js/common/ui/Validate.js demo体验狠狠地 ...
- Django基础之Form表单验证
Form表单验证 1.创建Form类(本质就是正则表达式的集合) from django.forms import Form from django.forms import fields from ...
- jQuery学习之路(8)- 表单验证插件-Validation
▓▓▓▓▓▓ 大致介绍 jQuery Validate 插件为表单提供了强大的验证功能,让客户端表单验证变得更简单,同时提供了大量的定制选项,满足应用程序各种需求.该插件捆绑了一套有用的验证方法,包括 ...
- 玩转spring boot——AOP与表单验证
AOP在大多数的情况下的应用场景是:日志和验证.至于AOP的理论知识我就不做赘述.而AOP的通知类型有好几种,今天的例子我只选一个有代表意义的“环绕通知”来演示. 一.AOP入门 修改“pom.xml ...
- form表单验证-Javascript
Form表单验证: js基础考试内容,form表单验证,正则表达式,blur事件,自动获取数组,以及css布局样式,动态清除等.完整代码如下: <!DOCTYPE html PUBLIC &qu ...
随机推荐
- Java NIO教程 MappedByteBuffer
之前跟大家说过,要讲MappedByteBuffer,现在我来履行承诺了. 首先从大体上讲一下MappedByteBuffer究竟是什么.从继承结构上来讲,MappedByteBuffer继承自Byt ...
- Linux/Unix双机建立信任教程
Linux/Unix双机建立信任教程 一 需要建立信任关系的2台主机都执行生成密钥输入ssh-keygen -t rsa之后全部默认回车,这样就会在/root/.ssh下生成密钥文件 [root@pl ...
- CSS3样式问题
empty-cells 属性设置是否显示表格中的空单元格 tr:nth-child(even)偶数行的表格 li:nth-child(20)指定位置 2016-09-2813:23:45
- Matlab学习(一):数字图像处理大作业用到的函数
1.dlmread——将以 ASCII 码分隔的数值数据读入到矩阵中 dt = dlmread(,); dt = dt(:,); save('data2.txt','dt','-ascii'); 2. ...
- ubuntu14.04 的网络配置
为eth0 配置网络 vi /etc/network/intefaces 添加以下内容 auto eth0 iface eth0 inet static address 192.168.0.10 ne ...
- vbox进行克隆时时启动eth0时问题
在进行虚拟机克隆时会出现mac地址冲突,在进行网卡启动时,会出现device eth0 does not seem to be present问题,解决方案如下: 问题描述: device eth0 ...
- Activity使用startActivityForResult时出现onActivityResult()不执行的问题
通过使用 startActivityForResult() 和 onActivityResult() 方法可以在Activity之间传递或接收参数.但有时候我们会遭遇onActivityResult( ...
- 使用 IntraWeb (40) - 自定义 Session 数据
修改 UserSessionUnit 单元: unit UserSessionUnit; interface uses IWUserSessionBase, SysUtils, Classes, IW ...
- DELPHI优秀的一些开源框架:QDAC,MORMOT,DIOCP
DELPHI优秀的一些开源框架:QDAC,MORMOT,DIOCP 程序员搞任何语言的程序开发上升到一定的层次,要想进步,必须要接触和学习使用优秀的开源框架. MORMOT封装了WINDOWS最新的H ...
- option2
option = { tooltip : { show: true, trigger: 'item' }, legend: { data:['邮件营销','联盟广告','直接访问','搜索引擎'] } ...