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 ...
随机推荐
- MySql Host is blocked because of many connection errors; unblock with 'mysqladmin flush-hosts' 解决方法
环境:linux,mysql5.5.21 错误:Host is blocked because of many connection errors; unblock with 'mysqladmin ...
- sql ltrim rtrim
sql中用LTRIM ( ),RTRIM ( ).分别截断首尾空格,返回字符表达式. 例1: DECLARE @string_to_trim varchar(60)SET @string_to_tri ...
- quartus ii13.0~16.0 调用uedit (转载http://blog.sina.com.cn/s/blog_6d5560f00102vax6.html)
转自 http://blog.sina.com.cn/s/blog_6d5560f00102vax6.html Quartus II 中的文本编辑软件不好用,比较习惯与UE(Uedit32/ultra ...
- winform-全局异常捕获作用
using System;using System.Collections.Generic;using System.Linq;using System.Windows.Forms;using Jxs ...
- memcache与memcached介绍及安装配置
也许大家一看到Memcache和Memcached会有点晕,这两者有什么关系又有什么区别呢,下面先给大家说下Memcached,Memcached是一个高性能的分布式内存对象缓存系统,用于动态Web应 ...
- 运行iis出现:The server has encountered an error while loading an application ……的解决办法【转】
本人测试了下,第三种方法成功了. 然后经过网上搜索,3种解决方法: 第一种: MC检测到此管理单元发生一个错误.建议关闭并重新启动MMC 要变通解决此问题, 请按照下列步骤操作进入 WMI MMC 管 ...
- web大文件上传控件-jsp-oracle-bug修复-Xproer.HttpUploader6
说明: 修复删除文件夹逻辑错误的问题 1.更新up6.js 更新前: 更新后: 代码: , "RemoveFolder": function (fileSvr) ...
- PXE-kickstart无人值守批量装机
服务器的批量部署: 规模化:同时装配多台服务器 自动化:安装系统.配置各种服务 远程实现:不需要光盘.U盘等安装介质 PXE,Pre-boot eXcution Environment 预启动执行环境 ...
- Xml序列化UTF-8格式错误
我需要得到一个类的Xml序列化后的字符串 using (System.IO.MemoryStream mem = new System.IO.MemoryStream()) { XmlTextWrit ...
- 在VLFEAT中mat类型图片转换成constant float* 来进行vl_dsift_process
How to convert an OpenCV cv::Mat into a float* that can be fed into Vlfeat vl_dsift_process: Mat mat ...