EasyUI表单验证插件扩展
$.extend($.fn.validatebox.defaults.rules, {
regex: {
validator: function (value, param) {
var regex = new RegExp(param[0]);
regex.ignoreCase = true;
regex.global= true;
return regex.test(value);
},
message: '请输入正确的信息'
},
minlength: {
validator: function (value, param) {
return value.length >= param[0];
},
message: '长度至少为{0}位.'
},
IDNumber: {
validator: function (value, param) {
var num = value;
if (num.length != 15 && num.length != 18) {
return false;
}
var pattern = /^(\d{6})(18|19|20)?(\d{2})([01]\d)([0123]\d)(\d{3})(\d|[Xx])?$/; //2个问号是针对15位的 所以这里会导致有一些BUG
if (!pattern.test(num)) return false;
else if (num.length == 18) {
var arr = new Array(18);
for (var i = 0; i < num.length; i++) {
arr[i] = num.charAt(i);
}
num = arr;
var wi = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1]; // 加权因子
var valideCode = [1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2]; // 身份证验证位值.10代表X
var sum = 0; // 声明加权求和变量
if (num[17].toLowerCase() == 'x') {
num[17] = 10; // 将最后位为x的验证码替换为10方便后续操作
}
for (var i = 0; i < 17; i++) {
sum += wi[i] * num[i]; // 加权求和
}
valCodePosition = sum % 11; // 得到验证码所位置
return num[17] == valideCode[valCodePosition];
}
else return true;
},
message: '请输入正确的身份证号'
},
faxno: {// 验证传真
validator: function (value) {
// return /^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/i.test(value);
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);
},
message: '传真号码不正确'
},
passwords: {
validator: function (value, param) {
var old = $('#' + param).val();
if (value == old) {
return true;
} else {
return false;
}
},
message: '两次输入的密码不一致'
},
CHS: {
validator: function (value, param) {
return /^[\u4e00-\u9fa5]+$/.test(value);
},
message: '请输入汉字'
},
ZIP: {
validator: function (value, param) {
return /^[1-9]\d{5}$/.test(value);
},
message: '邮政编码不存在'
},
QQ: {
validator: function (value, param) {
return /^[1-9]\d{4,10}$/.test(value);
},
message: 'QQ号码不正确'
},
phone: {// 验证电话号码
validator: function (value) {
//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);
return /^(\(?\d{2,3}\)?\-?)?[1-9]\d{6,19}(\-?\(?\d{1,4}\)?\-?)?$/i.test(value);
},
//message: '格式不正确,请使用下面格式:010-88888888'
message: '格式不正确'
},
mobile: {
validator: function (value, param) {
//return /^((\(\d{2,3}\))|(\d{3}\-))?13\d{9}$/.test(value);
//return /^1[3|4|5|8][0-9]\d{8}$/.test(value);
return /^1[0-9]{10}$/.test(value);
},
message: '手机号码不正确'
},
phoneormobile: {// 验证电话号码及手机
validator: function (value) {
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);
},
message: '手机或固话格式不正确,固话格式如:010-88888888,手机格式:11位数字'
},
loginName: {
validator: function (value, param) {
return /^[\u4e00-\u9fa5\w_]+$/.test(value);
},
message: '只允许汉字、英文字母、数字及下划线'
},
name: {// 验证姓名,可以是中文或英文
validator: function (value) {
return /^[\Α-\¥]+$/i.test(value) | /^\w+[\w\s]+\w+$/i.test(value);
},
message: '请输入中文'
},
unnormal: {// 验证是否包含空格和非法字符
validator: function (value) {
return /.+/i.test(value);
},
message: '输入值不能为空和包含其他非法字符'
},
safepass: {
validator: function (value, param) {
return safePassword(value);
},
message: '密码由字母和数字组成,至少6位'
},
equalTo: {
validator: function (value, param) {
return value == $(param[0]).val();
},
message: '两次输入的字符不一至'
},
number: {
validator: function (value, param) {
return /^\d+$/.test(value);
},
message: '请输入数字'
},
idcard: {
validator: function (value, param) {
return idCard(value);
},
message: '请输入正确的身份证号码'
},
macNum: {
validator: function (value, param) {
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);
},
message: '请输入正确的MacNum'
},
integer: {
validator: function (value) {
return /^[+]?[1-9]+\d*$/i.test(value);
},
message:"请输入整数"
}, ageWeiHuoYunShu: {
validator: function (value) {
var r = /^[+]?[1-9]+\d*$/i.test(value);
if (r) {
if (value > 17 && value < 61)
return true;
else
return false;
}
return false;
},
message: "范围为18~60"
},
age: {
validator: function (value) {
return /^/.test(value);
}
},
// 正数(不包括0)
positive: {
validator: function (value) {
return /^$|^([1-9][0-9]*(\.\d+)?)$|^0\.\d*[1-9]\d*$/.test(value);
},
message: "请输入大于0的数字"
}, // 整数或小数
custominteger:{
validator: function (value) {
return /^[0-9]+([.]{1}[0-9]+){0,1}$/.test(value);
},
message: "请输入正确的数字"
},
// 正整数(大于0的整数)
positiveinteger: {
validator: function (value) {
return /^[1-9]\d*$/.test(value);
},
message: "请输入大于0的整数"
},
// 大于等于0的整数(不能以0开头)
zerointeger: {
validator: function (value) {
return /^(0|[1-9][0-9]*)$/.test(value);
},
message: "请输入大于或等于0的数字"
},
bank:{
validator: function (value) {
return /^[0-9]{16,19}$/.test(value);
},
message: "请输入正确的银行帐号"
},
//2015-07-16
email: {
validator: function (value) {
return /^([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+\.[a-zA-Z]{2,3}$/.test(value);
},
message: "电子邮箱格式不正确"
},
mobileorphone: {
validator: function (value) {
return /^1[0-9]{10}$|^([0-9]{3,4}-)?[0-9]{7,8}$/.test(value);
},
message: "请输入正确的手机或座机号码"
},
ZIPCode: { //邮编
validator: function (value, param) {
return /^[1-9]\d{5}$/.test(value);
},
message: '邮政编码不存在'
},
// 身份证号码()
idcard_Interface: {
validator: function (value) {
return /^$|^\d{17}(\d|x|X)$/.test(value);
},
message: "请输入正确的身份证号码"
}, IDCard: { //身份证号
validator: function (value, param) {
var num = value;
if (num.length != 15 && num.length != 18) {
return false;
}
var pattern = /^(\d{15}$|^\d{18}$|^\d{17}(\d|X|x))$/;
if (!pattern.test(num)) return false;
if (num.length == 15) {
var year = num.substring(6, 8);
var month = num.substring(8, 10);
var day = num.substring(10, 12);
var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day));
if (temp_date.getYear() != parseFloat(year)
|| temp_date.getMonth() != parseFloat(month) - 1
|| temp_date.getDate() != parseFloat(day)) {
return false;
} else {
return true;
}
}
else if (num.length == 18) {
var arr = new Array(18);
for (var i = 0; i < num.length; i++) {
arr[i] = num.charAt(i);
}
num = arr;
var wi = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1]; // 加权因子
var valideCode = [1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2]; // 身份证验证位值.10代表X
var sum = 0; // 声明加权求和变量
if (num[17].toLowerCase() == 'x') {
num[17] = 10; // 将最后位为x的验证码替换为10方便后续操作
}
for (var i = 0; i < 17; i++) {
sum += wi[i] * num[i]; // 加权求和
}
valCodePosition = sum % 11; // 得到验证码所位置
return num[17] == valideCode[valCodePosition];
}
else return true;
},
message: '请输入正确的身份证号'
}, date: { //日期格式(yyyy-MM-dd、yyyy/MM/dd)
validator: function (value, param) {
//debugger;
var reg = /^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/;
var r = value.match(reg);
if (r == null) return false;
var d = new Date(r[1], r[3] - 1, r[4]);
return (d.getFullYear() == r[1] && (d.getMonth() + 1) == r[3] && d.getDate() == r[4]);
},
message: '日期格式错误!格式为:yyyy-MM-dd、yyyy/MM/dd'
},
datetime: { //日期时间格式(yyyy-MM-dd HH:mm:ss、yyyy/MM/dd HH:mm:ss)
validator: function (value, param) {
var reg = /^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/;
var r = value.match(reg);
if (r == null) return false;
var d = new Date(r[1], r[3] - 1, r[4], r[5], r[6], r[7]);
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]);
},
message: '时间格式错误!格式为:yyyy-MM-dd HH:mm:ss、yyyy/MM/dd HH:mm:ss'
}, chepaihaoGangAoTai: {
validator: function (value, param) {
return (/^粤Z{1}[A-Za-z0-9挂]{5}$/.test(value));
},
message: '港澳台内地车牌号格式:粤Zxxxxx(x为字母、数字、或“挂”字)'
}, chepaihao: {
validator: function (value, param) {
return (/^粤[A-Za-z]{1}[A-Za-z0-9挂]{5}$/.test(value));
},
message: '内地车牌号格式:粤yxxxxx(y为字母,x为字母、数字、或“挂”字)'
} });
var safePassword = function (value) {
return !(/^(([A-Z]*|[a-z]*|\d*|[-_\~!@#\$%\^&\*\.\(\)\[\]\{\}<>\?\\\/\'\"]*)|.{0,5})$|\s/.test(value));
} var idCard = function (value) {
if (value.length == 18 && 18 != value.length) return false;
var number = value.toLowerCase();
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';
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])))$/);
if (re == null || a.indexOf(re[1]) < 0) return false;
if (re[2].length == 9) {
number = number.substr(0, 6) + '19' + number.substr(6);
d = ['19' + re[4], re[5], re[6]].join('-');
} else d = [re[9], re[10], re[11]].join('-');
if (!isDateTime.call(d, 'yyyy-MM-dd')) return false;
for (var i = 0; i < 17; i++) sum += number.charAt(i) * w[i];
return (re[2].length == 9 || number.charAt(17) == v.charAt(sum % 11));
} var isDateTime = function (format, reObj) {
format = format || 'yyyy-MM-dd';
var input = this, o = {}, d = new Date();
var f1 = format.split(/[^a-z]+/gi), f2 = input.split(/\D+/g), f3 = format.split(/[a-z]+/gi), f4 = input.split(/\d+/g);
var len = f1.length, len1 = f3.length;
if (len != f2.length || len1 != f4.length) return false;
for (var i = 0; i < len1; i++) if (f3[i] != f4[i]) return false;
for (var i = 0; i < len; i++) o[f1[i]] = f2[i];
o.yyyy = s(o.yyyy, o.yy, d.getFullYear(), 9999, 4);
o.MM = s(o.MM, o.M, d.getMonth() + 1, 12);
o.dd = s(o.dd, o.d, d.getDate(), 31);
o.hh = s(o.hh, o.h, d.getHours(), 24);
o.mm = s(o.mm, o.m, d.getMinutes());
o.ss = s(o.ss, o.s, d.getSeconds());
o.ms = s(o.ms, o.ms, d.getMilliseconds(), 999, 3);
if (o.yyyy + o.MM + o.dd + o.hh + o.mm + o.ss + o.ms < 0) return false;
if (o.yyyy < 100) o.yyyy += (o.yyyy > 30 ? 1900 : 2000);
d = new Date(o.yyyy, o.MM - 1, o.dd, o.hh, o.mm, o.ss, o.ms);
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;
return reVal && reObj ? d : reVal;
function s(s1, s2, s3, s4, s5) {
s4 = s4 || 60, s5 = s5 || 2;
var reVal = s3;
if (s1 != undefined && s1 != '' || !isNaN(s1)) reVal = s1 * 1;
if (s2 != undefined && s2 != '' && !isNaN(s2)) reVal = s2 * 1;
return (reVal == s1 && s1.length != s5 || reVal > s4) ? -10000 : reVal;
}
}
EasyUI表单验证插件扩展的更多相关文章
- 写一个简单易用可扩展vue表单验证插件(vue-validate-easy)
写一个vue表单验证插件(vue-validate-easy) 需求 目标:简单易用可扩展 如何简单 开发者要做的 写了一个表单,指定一个name,指定其验证规则. 调用提交表单方法,可以获取验证成功 ...
- jquery validate表单验证插件-推荐
1 表单验证的准备工作 在开启长篇大论之前,首先将表单验证的效果展示给大家. 1.点击表单项,显示帮助提示 2.鼠标离开表单项时,开始校验元素 3.鼠标离开后的正确.错误提示及鼠标移入时的帮 ...
- jquery validate表单验证插件
1 表单验证的准备工作 在开启长篇大论之前,首先将表单验证的效果展示给大家. 1.点击表单项,显示帮助提示 2.鼠标离开表单项时,开始校验元素 3.鼠标离开后的正确.错误提示及鼠标移入时的帮 ...
- 表单验证插件 - formValidator
表单验证插件 - formValidator * 引入formValidator插件文件 * 引入formValidator插件的主文件 * 引入formValidator插件的正则有关文件 * 引入 ...
- Jquery.validate.js表单验证插件的使用
作为一个网站web开发人员,以前居然不知道还有表单验证这样好呀的插件,还在一行行写表单验证,真是后悔没能早点知道他们的存在. 最近公司不忙,自己学习一些东西的时候,发现了validation的一个实例 ...
- jQuery formValidator表单验证插件
什么是jQuery formValidator? jQuery formValidator表单验证插件是客户端表单验证插件. 在做B/S开发的时候,我们经常涉及到很多表单验证,例如新用户注册,填写个人 ...
- (转)强大的JQuery表单验证插件 FormValidator使用介绍
jQuery formValidator表单验证插件是客户端表单验证插件.在做B/S开发的时候,我们经常涉及到很多表单验证,例如新用户注册,填写个人资料,录入一些常规数据等等.在这之前,页面开发者(J ...
- 强大的JQuery表单验证插件 FormValidator使用介绍
jQuery formValidator表单验证插件是客户端表单验证插件. 在做B/S开发的时候,我们经常涉及到很多表单验证,例如新用户注册,填写个人资料,录入一些常规数据等等.在这之前,页面开发者( ...
- jQuery html5Validate基于HTML5表单验证插件
更新于2016-02-25 前面提到的新版目前线上已经可以访问: http://mp.gtimg.cn/old_mp/assets/js/common/ui/Validate.js demo体验狠狠地 ...
随机推荐
- Vmware14 开机黑屏或者以独占方式锁定此配置文件失败等问题解决办法
把VMware14版本卸载掉,然后重装一个12版本的 打开之前创建的虚拟机,提示版本不兼容, 打开配置文件: 修改版本为重装的版本,比如12 然后编辑虚拟机设置指定一个系统,比如centos,即可 就 ...
- zabbix3.4搭建微信报警
身为小白的我在历经被百度查到的资料坑了无数次之后,终于找到了一个正确的文档,下面是我自己的对于安装过程的理解与阐述. 一.申请微信企业号,获取以下数据. 企业ID:(在我们企业最下方可以看到) 应用的 ...
- 如何获取 C# 类中发生数据变化的属性信息
一.前言 在平时的开发中,当用户修改数据时,一直没有很好的办法来记录具体修改了那些信息,只能暂时采用将类序列化成 json 字符串,然后全塞入到日志中的方式,此时如果我们想要知道用户具体改变了哪几个字 ...
- K8S部署遇到的问题处理汇总
第一个: node节点注册提示:failed to get config map: Unauthorized 代码如下: [root@node1 ~]# kubeadm join --token ll ...
- 快乐编程大本营【java语言训练班】第5课: java的数组编程
快乐编程大本营[java语言训练班]第5课: java的数组编程 第1节. 声明数组变量 第2节. 创建数组对象 第3节. 访问数组元素 第4节. 修改数组元素 第5节. 多维数组 学习地址如下:ht ...
- 实验14:VLAN间的路由
实验11-1: 单臂路由实现VLAN 间路由 Ø 实验目的通过本实验,读者可以掌握如下技能:(1) 路由器以太网接口上的子接口(2) 单臂路由实现VLAN 间路由的配置Ø 实验拓扑 实验步 ...
- Spring注入bean的方式
在Spring容器中为一个bean配置依赖注入有三种方式: · 使用属性的setter方法注入 这是最常用的方式: · 使用构造器注入: · 使用Filed注入(用于注解方式). 使用属性的se ...
- 让Android模拟器速度飞起来_Eclipse+BlueStacks调试Android应用【2012-10-30】
谨将此文献给无真机进行调试的各位同仁们,有真机的幸运儿请自觉飘过 原文地址:http://www.cnblogs.com/hbbbs/archive/2012/10/30/2746950.html 长 ...
- 时序数据库 Apache-IoTDB 源码解析之文件索引块(五)
上一章聊到 TsFile 的文件组成,以及数据块的详细介绍.详情请见: 时序数据库 Apache-IoTDB 源码解析之文件数据块(四) 打一波广告,欢迎大家访问IoTDB 仓库,求一波 Star. ...
- 机器学习(ML)十之CNN
CNN-二维卷积层 卷积神经网络(convolutional neural network)是含有卷积层(convolutional layer)的神经网络.卷积神经网络均使用最常见的二维卷积层.它有 ...