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中abstract的用法
1,abstract修饰类,会使这个类成为一个抽象类,这个类将不能生成对象实例,可以做为对象变量声明的类型,也就是编译时类型,抽象类就像当于一类的半成品,需要子类继承并覆盖其中的抽象方法. 2,abs ...
- javascript 网页运行代码效果
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8&qu ...
- Python:面向对象
面向过程:根据业务逻辑从上到下写垒代码 面向对象:对函数进行分类和封装 函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可 类:用来描述具有相同属性和方法的对象的集合,定义了该集合中 ...
- 【html/css】html/css命名规范
无论做什么,规则总是最重要的.无规矩不成方圆,有了规矩,我们才能有规可循,有则可依,人与人之间才能正常的交流交往. 人人都有自己的命名习惯,不过,代码是需要交流的,当有些命名习惯仅只自己能看懂,甚至自 ...
- css3新属性@ text-shadow
text-shodow是css3的新属性,可以利用这个属性使字体更有立体感,还可以创造有趣的效果. 1.语法形式:text-shadow : x-offset(x轴偏移量) y-offset(y轴偏移 ...
- linux下如何开启oracle服务和开启监听
su - oracle 切换到oracle用户模式下 sqlplus /nolog //登录sqlplus SQL> connect /as sysdba //连接oracle SQL&g ...
- poj3264 - Balanced Lineup(RMQ_ST)
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 45243 Accepted: 21240 ...
- oracle 根据字段分组后,将组内的数据根据字段排序
row_number() over(partition by 分组字段 order by 排序字段 desc)
- 5.2 Adapter
1 ArrayAdapter 只可以简单的显示一行文本 ArrayAdapter<String> adapter = new ArrayAdapter<String>( thi ...
- iOS 关于nil和Nil及null与<null>的区别
问题是这样的. NSDictionary *sample = [NSJSONSerialization JSONObjectWithData:received options:NSJSONReadin ...