1. $.extend($.fn.validatebox.defaults.rules, {
  2. regex: {
  3. validator: function (value, param) {
  4. var regex = new RegExp(param[0]);
  5. regex.ignoreCase = true;
  6. regex.global= true;
  7. return regex.test(value);
  8. },
  9. message: '请输入正确的信息'
  10. },
  11. minlength: {
  12. validator: function (value, param) {
  13. return value.length >= param[0];
  14. },
  15. message: '长度至少为{0}位.'
  16. },
  17. IDNumber: {
  18. validator: function (value, param) {
  19. var num = value;
  20. if (num.length != 15 && num.length != 18) {
  21. return false;
  22. }
  23. var pattern = /^(\d{6})(18|19|20)?(\d{2})([01]\d)([0123]\d)(\d{3})(\d|[Xx])?$/; //2个问号是针对15位的 所以这里会导致有一些BUG
  24. if (!pattern.test(num)) return false;
  25. else if (num.length == 18) {
  26. var arr = new Array(18);
  27. for (var i = 0; i < num.length; i++) {
  28. arr[i] = num.charAt(i);
  29. }
  30. num = arr;
  31. var wi = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1]; // 加权因子
  32. var valideCode = [1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2]; // 身份证验证位值.10代表X
  33. var sum = 0; // 声明加权求和变量
  34. if (num[17].toLowerCase() == 'x') {
  35. num[17] = 10; // 将最后位为x的验证码替换为10方便后续操作
  36. }
  37. for (var i = 0; i < 17; i++) {
  38. sum += wi[i] * num[i]; // 加权求和
  39. }
  40. valCodePosition = sum % 11; // 得到验证码所位置
  41. return num[17] == valideCode[valCodePosition];
  42. }
  43. else return true;
  44. },
  45. message: '请输入正确的身份证号'
  46. },
  47. faxno: {// 验证传真
  48. validator: function (value) {
  49. // return /^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/i.test(value);
  50. return /^((\(\d{2,3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$/i.test(value);
  51. },
  52. message: '传真号码不正确'
  53. },
  54. passwords: {
  55. validator: function (value, param) {
  56. var old = $('#' + param).val();
  57. if (value == old) {
  58. return true;
  59. } else {
  60. return false;
  61. }
  62. },
  63. message: '两次输入的密码不一致'
  64. },
  65. CHS: {
  66. validator: function (value, param) {
  67. return /^[\u4e00-\u9fa5]+$/.test(value);
  68. },
  69. message: '请输入汉字'
  70. },
  71. ZIP: {
  72. validator: function (value, param) {
  73. return /^[1-9]\d{5}$/.test(value);
  74. },
  75. message: '邮政编码不存在'
  76. },
  77. QQ: {
  78. validator: function (value, param) {
  79. return /^[1-9]\d{4,10}$/.test(value);
  80. },
  81. message: 'QQ号码不正确'
  82. },
  83. phone: {// 验证电话号码
  84. validator: function (value) {
  85. //return /^((\(\d{2,3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$/i.test(value);
  86. return /^(\(?\d{2,3}\)?\-?)?[1-9]\d{6,19}(\-?\(?\d{1,4}\)?\-?)?$/i.test(value);
  87. },
  88. //message: '格式不正确,请使用下面格式:010-88888888'
  89. message: '格式不正确'
  90. },
  91. mobile: {
  92. validator: function (value, param) {
  93. //return /^((\(\d{2,3}\))|(\d{3}\-))?13\d{9}$/.test(value);
  94. //return /^1[3|4|5|8][0-9]\d{8}$/.test(value);
  95. return /^1[0-9]{10}$/.test(value);
  96. },
  97. message: '手机号码不正确'
  98. },
  99. phoneormobile: {// 验证电话号码及手机
  100. validator: function (value) {
  101. return /^((\(\d{2,3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$|^1[0-9]{10}$/i.test(value);
  102. },
  103. message: '手机或固话格式不正确,固话格式如:010-88888888,手机格式:11位数字'
  104. },
  105. loginName: {
  106. validator: function (value, param) {
  107. return /^[\u4e00-\u9fa5\w_]+$/.test(value);
  108. },
  109. message: '只允许汉字、英文字母、数字及下划线'
  110. },
  111. name: {// 验证姓名,可以是中文或英文
  112. validator: function (value) {
  113. return /^[\Α-\¥]+$/i.test(value) | /^\w+[\w\s]+\w+$/i.test(value);
  114. },
  115. message: '请输入中文'
  116. },
  117. unnormal: {// 验证是否包含空格和非法字符
  118. validator: function (value) {
  119. return /.+/i.test(value);
  120. },
  121. message: '输入值不能为空和包含其他非法字符'
  122. },
  123. safepass: {
  124. validator: function (value, param) {
  125. return safePassword(value);
  126. },
  127. message: '密码由字母和数字组成,至少6位'
  128. },
  129. equalTo: {
  130. validator: function (value, param) {
  131. return value == $(param[0]).val();
  132. },
  133. message: '两次输入的字符不一至'
  134. },
  135. number: {
  136. validator: function (value, param) {
  137. return /^\d+$/.test(value);
  138. },
  139. message: '请输入数字'
  140. },
  141. idcard: {
  142. validator: function (value, param) {
  143. return idCard(value);
  144. },
  145. message: '请输入正确的身份证号码'
  146. },
  147. macNum: {
  148. validator: function (value, param) {
  149. return /^[a-f\d]{2}-[a-f\d]{2}-[a-f\d]{2}-[a-f\d]{2}-[a-f\d]{2}-[a-f\d]{2}$/.test(value);
  150. },
  151. message: '请输入正确的MacNum'
  152. },
  153. integer: {
  154. validator: function (value) {
  155. return /^[+]?[1-9]+\d*$/i.test(value);
  156. },
  157. message:"请输入整数"
  158. },
  159.  
  160. ageWeiHuoYunShu: {
  161. validator: function (value) {
  162. var r = /^[+]?[1-9]+\d*$/i.test(value);
  163. if (r) {
  164. if (value > 17 && value < 61)
  165. return true;
  166. else
  167. return false;
  168. }
  169. return false;
  170. },
  171. message: "范围为18~60"
  172. },
  173. age: {
  174. validator: function (value) {
  175. return /^/.test(value);
  176. }
  177. },
  178. // 正数(不包括0)
  179. positive: {
  180. validator: function (value) {
  181. return /^$|^([1-9][0-9]*(\.\d+)?)$|^0\.\d*[1-9]\d*$/.test(value);
  182. },
  183. message: "请输入大于0的数字"
  184. },
  185.  
  186. // 整数或小数
  187. custominteger:{
  188. validator: function (value) {
  189. return /^[0-9]+([.]{1}[0-9]+){0,1}$/.test(value);
  190. },
  191. message: "请输入正确的数字"
  192. },
  193. // 正整数(大于0的整数)
  194. positiveinteger: {
  195. validator: function (value) {
  196. return /^[1-9]\d*$/.test(value);
  197. },
  198. message: "请输入大于0的整数"
  199. },
  200. // 大于等于0的整数(不能以0开头)
  201. zerointeger: {
  202. validator: function (value) {
  203. return /^(0|[1-9][0-9]*)$/.test(value);
  204. },
  205. message: "请输入大于或等于0的数字"
  206. },
  207. bank:{
  208. validator: function (value) {
  209. return /^[0-9]{16,19}$/.test(value);
  210. },
  211. message: "请输入正确的银行帐号"
  212. },
  213. //2015-07-16
  214. email: {
  215. validator: function (value) {
  216. return /^([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+\.[a-zA-Z]{2,3}$/.test(value);
  217. },
  218. message: "电子邮箱格式不正确"
  219. },
  220. mobileorphone: {
  221. validator: function (value) {
  222. return /^1[0-9]{10}$|^([0-9]{3,4}-)?[0-9]{7,8}$/.test(value);
  223. },
  224. message: "请输入正确的手机或座机号码"
  225. },
  226. ZIPCode: { //邮编
  227. validator: function (value, param) {
  228. return /^[1-9]\d{5}$/.test(value);
  229. },
  230. message: '邮政编码不存在'
  231. },
  232. // 身份证号码()
  233. idcard_Interface: {
  234. validator: function (value) {
  235. return /^$|^\d{17}(\d|x|X)$/.test(value);
  236. },
  237. message: "请输入正确的身份证号码"
  238. },
  239.  
  240. IDCard: { //身份证号
  241. validator: function (value, param) {
  242. var num = value;
  243. if (num.length != 15 && num.length != 18) {
  244. return false;
  245. }
  246. var pattern = /^(\d{15}$|^\d{18}$|^\d{17}(\d|X|x))$/;
  247. if (!pattern.test(num)) return false;
  248. if (num.length == 15) {
  249. var year = num.substring(6, 8);
  250. var month = num.substring(8, 10);
  251. var day = num.substring(10, 12);
  252. var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day));
  253. if (temp_date.getYear() != parseFloat(year)
  254. || temp_date.getMonth() != parseFloat(month) - 1
  255. || temp_date.getDate() != parseFloat(day)) {
  256. return false;
  257. } else {
  258. return true;
  259. }
  260. }
  261. else if (num.length == 18) {
  262. var arr = new Array(18);
  263. for (var i = 0; i < num.length; i++) {
  264. arr[i] = num.charAt(i);
  265. }
  266. num = arr;
  267. var wi = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1]; // 加权因子
  268. var valideCode = [1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2]; // 身份证验证位值.10代表X
  269. var sum = 0; // 声明加权求和变量
  270. if (num[17].toLowerCase() == 'x') {
  271. num[17] = 10; // 将最后位为x的验证码替换为10方便后续操作
  272. }
  273. for (var i = 0; i < 17; i++) {
  274. sum += wi[i] * num[i]; // 加权求和
  275. }
  276. valCodePosition = sum % 11; // 得到验证码所位置
  277. return num[17] == valideCode[valCodePosition];
  278. }
  279. else return true;
  280. },
  281. message: '请输入正确的身份证号'
  282. },
  283.  
  284. date: { //日期格式(yyyy-MM-dd、yyyy/MM/dd)
  285. validator: function (value, param) {
  286. //debugger;
  287. var reg = /^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/;
  288. var r = value.match(reg);
  289. if (r == null) return false;
  290. var d = new Date(r[1], r[3] - 1, r[4]);
  291. return (d.getFullYear() == r[1] && (d.getMonth() + 1) == r[3] && d.getDate() == r[4]);
  292. },
  293. message: '日期格式错误!格式为:yyyy-MM-dd、yyyy/MM/dd'
  294. },
  295. datetime: { //日期时间格式(yyyy-MM-dd HH:mm:ss、yyyy/MM/dd HH:mm:ss)
  296. validator: function (value, param) {
  297. var reg = /^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/;
  298. var r = value.match(reg);
  299. if (r == null) return false;
  300. var d = new Date(r[1], r[3] - 1, r[4], r[5], r[6], r[7]);
  301. return (d.getFullYear() == r[1] && (d.getMonth() + 1) == r[3] && d.getDate() == r[4] && d.getHours() == r[5] && d.getMinutes() == r[6] && d.getSeconds() == r[7]);
  302. },
  303. message: '时间格式错误!格式为:yyyy-MM-dd HH:mm:ss、yyyy/MM/dd HH:mm:ss'
  304. },
  305.  
  306. chepaihaoGangAoTai: {
  307. validator: function (value, param) {
  308. return (/^粤Z{1}[A-Za-z0-9挂]{5}$/.test(value));
  309. },
  310. message: '港澳台内地车牌号格式:粤Zxxxxx(x为字母、数字、或“挂”字)'
  311. },
  312.  
  313. chepaihao: {
  314. validator: function (value, param) {
  315. return (/^粤[A-Za-z]{1}[A-Za-z0-9挂]{5}$/.test(value));
  316. },
  317. message: '内地车牌号格式:粤yxxxxx(y为字母,x为字母、数字、或“挂”字)'
  318. }
  319.  
  320. });
  321. var safePassword = function (value) {
  322. return !(/^(([A-Z]*|[a-z]*|\d*|[-_\~!@#\$%\^&\*\.\(\)\[\]\{\}<>\?\\\/\'\"]*)|.{0,5})$|\s/.test(value));
  323. }
  324.  
  325. var idCard = function (value) {
  326. if (value.length == 18 && 18 != value.length) return false;
  327. var number = value.toLowerCase();
  328. 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';
  329. 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])))$/);
  330. if (re == null || a.indexOf(re[1]) < 0) return false;
  331. if (re[2].length == 9) {
  332. number = number.substr(0, 6) + '19' + number.substr(6);
  333. d = ['19' + re[4], re[5], re[6]].join('-');
  334. } else d = [re[9], re[10], re[11]].join('-');
  335. if (!isDateTime.call(d, 'yyyy-MM-dd')) return false;
  336. for (var i = 0; i < 17; i++) sum += number.charAt(i) * w[i];
  337. return (re[2].length == 9 || number.charAt(17) == v.charAt(sum % 11));
  338. }
  339.  
  340. var isDateTime = function (format, reObj) {
  341. format = format || 'yyyy-MM-dd';
  342. var input = this, o = {}, d = new Date();
  343. var f1 = format.split(/[^a-z]+/gi), f2 = input.split(/\D+/g), f3 = format.split(/[a-z]+/gi), f4 = input.split(/\d+/g);
  344. var len = f1.length, len1 = f3.length;
  345. if (len != f2.length || len1 != f4.length) return false;
  346. for (var i = 0; i < len1; i++) if (f3[i] != f4[i]) return false;
  347. for (var i = 0; i < len; i++) o[f1[i]] = f2[i];
  348. o.yyyy = s(o.yyyy, o.yy, d.getFullYear(), 9999, 4);
  349. o.MM = s(o.MM, o.M, d.getMonth() + 1, 12);
  350. o.dd = s(o.dd, o.d, d.getDate(), 31);
  351. o.hh = s(o.hh, o.h, d.getHours(), 24);
  352. o.mm = s(o.mm, o.m, d.getMinutes());
  353. o.ss = s(o.ss, o.s, d.getSeconds());
  354. o.ms = s(o.ms, o.ms, d.getMilliseconds(), 999, 3);
  355. if (o.yyyy + o.MM + o.dd + o.hh + o.mm + o.ss + o.ms < 0) return false;
  356. if (o.yyyy < 100) o.yyyy += (o.yyyy > 30 ? 1900 : 2000);
  357. d = new Date(o.yyyy, o.MM - 1, o.dd, o.hh, o.mm, o.ss, o.ms);
  358. 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;
  359. return reVal && reObj ? d : reVal;
  360. function s(s1, s2, s3, s4, s5) {
  361. s4 = s4 || 60, s5 = s5 || 2;
  362. var reVal = s3;
  363. if (s1 != undefined && s1 != '' || !isNaN(s1)) reVal = s1 * 1;
  364. if (s2 != undefined && s2 != '' && !isNaN(s2)) reVal = s2 * 1;
  365. return (reVal == s1 && s1.length != s5 || reVal > s4) ? -10000 : reVal;
  366. }
  367. }

EasyUI表单验证插件扩展的更多相关文章

  1. 写一个简单易用可扩展vue表单验证插件(vue-validate-easy)

    写一个vue表单验证插件(vue-validate-easy) 需求 目标:简单易用可扩展 如何简单 开发者要做的 写了一个表单,指定一个name,指定其验证规则. 调用提交表单方法,可以获取验证成功 ...

  2. jquery validate表单验证插件-推荐

    1 表单验证的准备工作 在开启长篇大论之前,首先将表单验证的效果展示给大家.     1.点击表单项,显示帮助提示 2.鼠标离开表单项时,开始校验元素  3.鼠标离开后的正确.错误提示及鼠标移入时的帮 ...

  3. jquery validate表单验证插件

    1 表单验证的准备工作 在开启长篇大论之前,首先将表单验证的效果展示给大家.     1.点击表单项,显示帮助提示 2.鼠标离开表单项时,开始校验元素  3.鼠标离开后的正确.错误提示及鼠标移入时的帮 ...

  4. 表单验证插件 - formValidator

    表单验证插件 - formValidator * 引入formValidator插件文件 * 引入formValidator插件的主文件 * 引入formValidator插件的正则有关文件 * 引入 ...

  5. Jquery.validate.js表单验证插件的使用

    作为一个网站web开发人员,以前居然不知道还有表单验证这样好呀的插件,还在一行行写表单验证,真是后悔没能早点知道他们的存在. 最近公司不忙,自己学习一些东西的时候,发现了validation的一个实例 ...

  6. jQuery formValidator表单验证插件

    什么是jQuery formValidator? jQuery formValidator表单验证插件是客户端表单验证插件. 在做B/S开发的时候,我们经常涉及到很多表单验证,例如新用户注册,填写个人 ...

  7. (转)强大的JQuery表单验证插件 FormValidator使用介绍

    jQuery formValidator表单验证插件是客户端表单验证插件.在做B/S开发的时候,我们经常涉及到很多表单验证,例如新用户注册,填写个人资料,录入一些常规数据等等.在这之前,页面开发者(J ...

  8. 强大的JQuery表单验证插件 FormValidator使用介绍

    jQuery formValidator表单验证插件是客户端表单验证插件. 在做B/S开发的时候,我们经常涉及到很多表单验证,例如新用户注册,填写个人资料,录入一些常规数据等等.在这之前,页面开发者( ...

  9. jQuery html5Validate基于HTML5表单验证插件

    更新于2016-02-25 前面提到的新版目前线上已经可以访问: http://mp.gtimg.cn/old_mp/assets/js/common/ui/Validate.js demo体验狠狠地 ...

随机推荐

  1. spring源码系列(一):使用Gradle构建spring5源码的一些坑和步骤

    源代码github:  https://github.com/spring-projects/spring-framework.git 一 修改项目配置文件中gradle版本和地址 替换成本地安装的版 ...

  2. java线程池及创建多少线程合适

    java线程池 1.以下是ThreadPoolExecutor参数完备构造方法: public ThreadPoolExecutor(int corePoolSize,int maximumPoolS ...

  3. Codeforces_723_A

    http://codeforces.com/problemset/problem/723/A 取中间那个数就可以了,答案为最大值减最小值. #include<iostream> #incl ...

  4. input . type=number.使用后问题点

    所有主浏览器都支持type属性,但是,并非所有主流浏览器都支持所有不同的 input 类型. 以下 input 类型是 HTML5 中的新类型:color.date.datetime.datetime ...

  5. coroutine - yield from

    yield from yield from x 表达式对 x 对象所做的第一件事是,调用 iter(x),从中获取迭代器.因 此, x 可以是任何可迭代的对象. 可是,如果 yield from 结构 ...

  6. PyTorch可视化——tensorboard、visdom

    一.pytorch与tensorboard结合使用 Tensorboard Tensorboard一般都是作为tf的可视化工具,与tf深度集成,它能够展现tf的网络计算图,绘制图像生成的定量指标图以及 ...

  7. Python 模拟登录几种常见方法

    方法一:直接使用已知的cookie访问 优点: 简单,但需要先在浏览器登录 原理: 简单地说,cookie保存在发起请求的客户端中,服务器利用cookie来区分不同的客户端.因为http是一种无状态的 ...

  8. 兄弟连 企业shell笔试题 16-31

    企业实践题16:企业案例:写网络服务独立进程模式下rsync的系统启动脚本 例如:/etc/init.d/rsyncd{start|stop|restart} .要求:1.要使用系统函数库技巧.2.要 ...

  9. zabbix 自定义监控项报警给单独的人

    需求就是某个交换机的流量达到某个值后需要报警,但报警的内容不是发给所有的人,而是只发给特定的一个人,而其他的报警信息不能让他收到,他只能收到这一个报警项的报警 1:创建好用户定义好手机号 2:新增加一 ...

  10. nginX 安装 启动

    选择源码安装  下载安装包  nginx-1.8.0.tar.gz   解压                     tar -zxvf  nginx-1.8.0.tar.gz    进入文件夹   ...