easyui 的validatebox()提供了自定义验证的方法,为此我把一些常用的数据验证汇总了一下,代码如下:

  1. 代码
  2.  
  3. Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->$.extend($.fn.validatebox.defaults.rules, {
  4. CHS: {
  5. validator: function (value, param) {
  6. return /^[\u0391-\uFFE5]+$/.test(value);
  7. },
  8. message: '请输入汉字'
  9. },
  10. ZIP: {
  11. validator: function (value, param) {
  12. return /^[1-9]\d{5}$/.test(value);
  13. },
  14. message: '邮政编码不存在'
  15. },
  16. QQ: {
  17. validator: function (value, param) {
  18. return /^[1-9]\d{4,10}$/.test(value);
  19. },
  20. message: 'QQ号码不正确'
  21. },
  22. mobile: {
  23. validator: function (value, param) {
  24. return /^((\(\d{2,3}\))|(\d{3}\-))?13\d{9}$/.test(value);
  25. },
  26. message: '手机号码不正确'
  27. },
  28. loginName: {
  29. validator: function (value, param) {
  30. return /^[\u0391-\uFFE5\w]+$/.test(value);
  31. },
  32. message: '登录名称只允许汉字、英文字母、数字及下划线。'
  33. },
  34. safepass: {
  35. validator: function (value, param) {
  36. return safePassword(value);
  37. },
  38. message: '密码由字母和数字组成,至少6位'
  39. },
  40. equalTo: {
  41. validator: function (value, param) {
  42. return value == $(param[0]).val();
  43. },
  44. message: '两次输入的字符不一至'
  45. },
  46. number: {
  47. validator: function (value, param) {
  48. return /^\d+$/.test(value);
  49. },
  50. message: '请输入数字'
  51. },
  52. idcard: {
  53. validator: function (value, param) {
  54. return idCard(value);
  55. },
  56. message:'请输入正确的身份证号码'
  57. }
  58. });
  59.  
  60. /* 密码由字母和数字组成,至少6位 */
  61. var safePassword = function (value) {
  62. return !(/^(([A-Z]*|[a-z]*|\d*|[-_\~!@#\$%\^&\*\.\(\)\[\]\{\}<>\?\\\/\'\"]*)|.{0,5})$|\s/.test(value));
  63. }
  64.  
  65. var idCard = function (value) {
  66. if (value.length == 18 && 18 != value.length) return false;
  67. var number = value.toLowerCase();
  68. var d, sum = 0, v = '10x98765432', w = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2], a = '11,12,13,14,15,21,22,23,31,32,33,34,35,36,37,41,42,43,44,45,46,50,51,52,53,54,61,62,63,64,65,71,81,82,91';
  69. var re = number.match(/^(\d{2})\d{4}(((\d{2})(\d{2})(\d{2})(\d{3}))|((\d{4})(\d{2})(\d{2})(\d{3}[x\d])))$/);
  70. if (re == null || a.indexOf(re[1]) < 0) return false;
  71. if (re[2].length == 9) {
  72. number = number.substr(0, 6) + '19' + number.substr(6);
  73. d = ['19' + re[4], re[5], re[6]].join('-');
  74. } else d = [re[9], re[10], re[11]].join('-');
  75. if (!isDateTime.call(d, 'yyyy-MM-dd')) return false;
  76. for (var i = 0; i < 17; i++) sum += number.charAt(i) * w[i];
  77. return (re[2].length == 9 || number.charAt(17) == v.charAt(sum % 11));
  78. }
  79.  
  80. var isDateTime = function (format, reObj) {
  81. format = format || 'yyyy-MM-dd';
  82. var input = this, o = {}, d = new Date();
  83. var f1 = format.split(/[^a-z]+/gi), f2 = input.split(/\D+/g), f3 = format.split(/[a-z]+/gi), f4 = input.split(/\d+/g);
  84. var len = f1.length, len1 = f3.length;
  85. if (len != f2.length || len1 != f4.length) return false;
  86. for (var i = 0; i < len1; i++) if (f3[i] != f4[i]) return false;
  87. for (var i = 0; i < len; i++) o[f1[i]] = f2[i];
  88. o.yyyy = s(o.yyyy, o.yy, d.getFullYear(), 9999, 4);
  89. o.MM = s(o.MM, o.M, d.getMonth() + 1, 12);
  90. o.dd = s(o.dd, o.d, d.getDate(), 31);
  91. o.hh = s(o.hh, o.h, d.getHours(), 24);
  92. o.mm = s(o.mm, o.m, d.getMinutes());
  93. o.ss = s(o.ss, o.s, d.getSeconds());
  94. o.ms = s(o.ms, o.ms, d.getMilliseconds(), 999, 3);
  95. if (o.yyyy + o.MM + o.dd + o.hh + o.mm + o.ss + o.ms < 0) return false;
  96. if (o.yyyy < 100) o.yyyy += (o.yyyy > 30 ? 1900 : 2000);
  97. d = new Date(o.yyyy, o.MM - 1, o.dd, o.hh, o.mm, o.ss, o.ms);
  98. var reVal = d.getFullYear() == o.yyyy && d.getMonth() + 1 == o.MM && d.getDate() == o.dd && d.getHours() == o.hh && d.getMinutes() == o.mm && d.getSeconds() == o.ss && d.getMilliseconds() == o.ms;
  99. return reVal && reObj ? d : reVal;
  100. function s(s1, s2, s3, s4, s5) {
  101. s4 = s4 || 60, s5 = s5 || 2;
  102. var reVal = s3;
  103. if (s1 != undefined && s1 != '' || !isNaN(s1)) reVal = s1 * 1;
  104. if (s2 != undefined && s2 != '' && !isNaN(s2)) reVal = s2 * 1;
  105. return (reVal == s1 && s1.length != s5 || reVal > s4) ? -10000 : reVal;
  106. }
  107. };

自定义表单验证,实例:

  1. $.extend($.fn.validatebox.defaults.rules, {
  2. selectValueRequired: {
  3. validator: function(value,param){
  4. return value != '---请选择---';
  5. },
  6. message: '请选择车辆类型'
  7. }
  8. });
  9. $.extend($.fn.validatebox.defaults.rules, {
  10. NUMBERNON: {
  11. validator: function (value, param) {
  12. return /^[0123456789]\d{0,7}(\.\d{1,2})?$/.test(value);
  13. },
  14. message: '请输入非负数字,最多两位小数'
  15. }
  16. });

easyui 表单验证validatetype——支持自定义验证的更多相关文章

  1. EasyUI表单验证,自定义插件验证,自定义js插件验证,远程验证,常见手机号,中英文,qq等验证规则验证

     { field : 'startPort', title : "起始端口", editor: "text", width : 50, editor: { ...

  2. 雷林鹏分享:jQuery EasyUI 表单 - 表单验证

    jQuery EasyUI 表单 - 表单验证 本教程将向您展示如何验证一个表单.easyui 框架提供一个 validatebox 插件来验证一个表单.在本教程中,我们将创建一个联系表单,并应用 v ...

  3. easyUI表单验证

    1.重写easyui中的 $.extend($.fn.validatebox.defaults.rules, { }) 2.长度重写的方式 1 $.extend($.fn.validatebox.de ...

  4. jQuery Validate 插件为表单提供了强大的验证功能

    之前项目开发中,表单校验用的jQuery Validate 插件,这个插件为表单提供了强大的验证功能,让客户端表单验证变得更简单,同时提供了大量的定制选项,满足应用程序各种需求.该插件捆绑了一套有用的 ...

  5. 7、easyui 表单

    这是最后一个小节了,后面将会使用一个小项目来进一步实用讲解: 在之前的什么相关只是点都以及讲过了或者说涉及到过,如datagrid表格,树形菜单,布局面板panel,页签,拖放功能,只是在表格的属性细 ...

  6. easyUI表单基础知识

    easyUI创建异步提交表单 我们创建一个带有 name.email 和 phone 字段的表单.通过使用 easyui 表单(form)插件来改变表单(form)为 ajax 表单(form).表单 ...

  7. amazeui的表单开关插件的自定义事件必须添加.bootstrapSwitch 命名空间,给了我们什么启示

    amazeui的表单开关插件的自定义事件必须添加.bootstrapSwitch 命名空间,给了我们什么启示 一.总结 一句话总结:详细看使用文档(说明文档说的真的是非常详细呢,不过循序渐进,不同阶段 ...

  8. easyui表单插件-包括日期时控件-列表

    ← jQuery EasyUI 表单插件 – Numberspinner 数值微调器 jQuery EasyUI 表单插件 - Timespinner 时间微调器  jQuery EasyUI 插件 ...

  9. easyui表单提交,后台获取不到值

    J2ee开发,使用easyui表单提交,在ie中可以正常将参数传递到后台,但使用firefox,chrome都无法将easyui的combobox值传递到后台,使用alert($('#form').s ...

随机推荐

  1. 2013第49周一jsp标签

    2013第49周一jsp标签 今天在调试一些前台页面上的问题,在处理structs标签.jstl标签时遇到了些麻烦,为了调用后台数据字典中的类方法,开始在<c:forEach>中尝试怎么样 ...

  2. TCP快速重传和快速恢复

    当tcp传送一个分组时会设置一个定时器,如果在规定的实际间隔内没有收到ACK分组,那么则重新传输该分组,但是 如果tcp收到三个连续的ACK分组,此时不管是否过超时间隔则重传该分组,具体步骤如下: 1 ...

  3. hdu 5248 序列变换(二分枚举)

    Problem Description 给定序列A={A1,A2,...,An}, 要求改变序列A中的某些元素,形成一个严格单调的序列B(严格单调的定义为:Bi<Bi+,≤i<N). 我们 ...

  4. Qt之模型/视图(委托)

    # -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' from PyQt4.Qt import * from PyQt4. ...

  5. web前端 - 模态对话框

    代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8& ...

  6. MYSQL免安装版使用说明

    1>把压缩文件mysql-noinstall-5.1.6-alpha-win32.zip解压到一个目录下,在环境变量中设置MYSQL_HOME,把%MYSQL_HOME%\bin 加入到 pat ...

  7. 已解决 C# 调用 MySQLDriverCS 类库 报 vshost32-clr2.exe 已停止工作

    这几天修改一个项目是用C# 通过调用 MySQLDriverCS.dll 类库来操作 MySql数据库, 调试的会发生以上错误(直接运行是正常的),刚开始以为是兼容性问题,吧此错误百度上一粘贴有的人说 ...

  8. Android WebView 软键盘挡住输入框

    解决方法一: 在所在的Activity中加入 getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_ADJUST_RES ...

  9. servlet乱码以及解决

    //  浏览器提交的数据是000110011(码表中对应的<编码> )等东西. // 浏览器以什么<码表>打开浏览器(而空中浏览器使用的编码是:<meta http-eq ...

  10. redhat换yum源

    根据redhat操作系统版本及位数,下载对应centos的版本及位数的这些包: yum-3.2.22-40.el5.centos.noarch.rpm yum-fastestmirror-1.1.16 ...