表单验证&&常用正则


;(function(ELF){
ELF = ELF || (window.ELF = {});
var reg = {},
pattern = {
/*用户名校验*/
'userName' : '^[a-zA-Z0-9_-]{4,16}$',
/*姓名校验*/
'name' : '^[A-Za-z\.\u4e00-\u9fa5]+$',
/*手机号校验*/
'MPhone' : '^1[34578]\\d{9}$',
/*邮编校验*/
'zipCode' : '^\\d{6}$',
/*邮箱校验*/
'mail' : '^([A-Za-z0-9_\\-\\.])+@([A-Za-z0-9_\\-\\.])+\\.([A-Za-z]{2,4})$',
/*身份证简单校验 15位或者18位*/
'IDCode' : '^(([0-9]{14})|([0-9]{17}))[0-9X]$'
};
ELF.pattern = pattern;
ELF.reg = reg; //验证用户名:数字、字母、- {4-16}
reg.testUserName = function(arg){
arg = arg || '';
if(typeof arg !== "string") {
throw new TypeError('"arg" is not string');
}
return /^[a-zA-Z0-9_-]{4,16}$/.test(arg);
} //验证姓名: 字母或者中文
reg.testName = function( arg ){
arg = arg || '';
if(typeof arg !== "string") {
throw new TypeError('"arg" is not string');
}
return /^[A-Za-z\.\u4e00-\u9fa5]+$/.test( arg );
} //验证手机 :1 [3、4、5、7、8] 11位数字
reg.testMPhone = function ( arg ){
arg = arg || '';
if(typeof arg !== "string") {
throw new TypeError('"arg" is not string');
}
return /^1[34578]\d{9}$/.test( arg );
} //验证邮编 : 6位数字
reg.testZipCode = function(arg){
arg = arg || '';
if(typeof arg !== "string") {
throw new TypeError('"arg" is not string');
}
return /^\d{6}$/.test( arg );
} //验证邮箱: [数字、字母、_、- ]@[数字、字母、_、- 、.].[字母{2-4}]
reg.testMail = function(arg){
arg = arg || '';
if(typeof arg !== "string") {
throw new TypeError('"arg" is not string');
}
return /^([A-Za-z0-9_\-\.])+@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/.test(arg);
} //匹配身份证:严格匹配
reg.testIDCode = function( sId ) { sId = sId || '';
if(typeof sId !== "string") {
throw new TypeError('"sId" is not string');
} var aCity={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 iSum = 0;
var info = "";
var pass = true;
if(!/^\d{17}(\d|x)$/i.test(sId)){
info = "你输入的身份证长度或格式错误";
console.log( info );
return false;
}
sId = sId.replace(/x$/i, "a");
if(aCity[parseInt(sId.substr(0, 2))] == null){
info = "你的身份证地区非法";
console.log( info );
return false; }
sBirthday = sId.substr(6, 4) + "-" + Number(sId.substr(10, 2)) + "-" + Number(sId.substr(12, 2));
var d = new Date(sBirthday.replace(/-/g, "/"));
if(sBirthday != (d.getFullYear() + "-" + (d.getMonth() + 1) + "-" + d.getDate())){
info = "身份证上的出生日期非法";
console.log( info );
return false;
}
for(var i = 17; i >= 0; i--){
iSum += (Math.pow(2, i) % 11) * parseInt(sId.charAt(17 - i), 11);
}
if(iSum % 11 != 1){
info = "你输入的身份证号非法";
console.log( info );
return false;
}
console.log(info);
//aCity[parseInt(sId.substr(0,2))]+","+sBirthday+","+(sId.substr(16,1)%2?"男":"女");//此次还可以判断出输入的身份证号的人性别
return pass;
} })();

常用表单验证&&常用正则的更多相关文章

  1. 一个PHP常用表单验证类(基于正则)

    一个基于正则表达式的PHP常用表单验证类,作者:欣然随风.这个表单判断类的功能有:验证是否为指定长度的字母/数字组合.验证是否为指定长度汉字.身 份证号码验证.是否是指定长度的数字.验证邮件地址.电话 ...

  2. php常用表单验证类用法实例

    <?php /** * 页面作用:常用表单验证类 * 作 者:欣然随风 * QQ:276624915 */ class class_post { //验证是否为指定长度的字母/数字组合 func ...

  3. iview表单验证之正则验证、函数验证

    iview表单验证之正则 正则验证: 代码: loginRules: { stringLength: [ { required: true, message: '该字段不能为空', trigger: ...

  4. JavaScript常用表单验证正则表达式(身份证、电话号码、邮编、日期、IP等)

    身份证正则表达式 //身份证正则表达式(15位)isIDCard1=/^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$/;//身份证正则表达式 ...

  5. 前端表单验证常用的15个JS正则表达式

    在表单验证中,使用正则表达式来验证正确与否是一个很频繁的操作,本文收集整理了15个常用的javaScript正则表达式,其中包括用户名.密码强度.整数.数字.电子邮件地址(Email).手机号码.身份 ...

  6. 表单验证常用的JS正则表达式

    在表单验证中,使用正则表达式来验证正确与否是一个很频繁的操作,本文收集整理了15个常用的javaScript正则表达式,其中包括用户名.密码强度.整数.数字.电子邮件地址(Email).手机号码.身份 ...

  7. JavaScript---网络编程(12)--DHTML技术演示(5)-form表单验证技术(正则)

    这里不进行很复杂的后台验证以及JavaScript的正则表达式,只是简单的介绍下这个技术,简单的后台接收与跳转,大概了解怎么验证的就可以.具体的技术,我后面还会继续写博客的.本人也还在学习中. 表单验 ...

  8. js实现表单验证 常用JS表单验证

    CSS代码 @charset "gb2312"; /* CSS Document */ body,dl,dt,dd,div,form {padding:;margin:;} #he ...

  9. 关于JS中的常用表单验证+正则表达式

    一.非空验证 trim:去空格(去掉前后的空格),任何字符串都可以用这个方法.写法为:if(v.trim().length==0),表示如果去掉空格后的字符串的长度为0. <body> & ...

随机推荐

  1. EntityFrameWork实现部分字段获取和修改(含源码)

    EntityFrameWork类库,是微软推出的ORM组件,它是基于Ado.Net的,个人感觉还是非常 好用的.以下介绍的2个功能点分别是部分字段更新和获取 解决部分字段Update.本方案采用仓储模 ...

  2. appium+Python 启动app(二)

    我们上步操作基本完成,下面介绍编写Python脚本启动app 打开我们pycharm新建.py文件 第一步:输入Python脚本代码: #coding=utf-8 from appium import ...

  3. bzoj 3048[Usaco2013 Jan]Cow Lineup 思想,乱搞 stl

    3048: [Usaco2013 Jan]Cow Lineup Time Limit: 2 Sec  Memory Limit: 128 MBSubmit: 237  Solved: 168[Subm ...

  4. JavaScript 一个进行枚举选择的jquery插件(仿easyui风格)

    某次做项目要实现一个功能: 按星期选择一个连续的时间范围 比如:周一到周五,周六到周日 或 周六到周三 聪明的朋友马上想出办法:用两个选项为周一到周日的下拉列表实现,对 那样可以,但是我觉得不够友好, ...

  5. xBIM WeXplorer 设置模型颜色

    目录 基础 xBIM WeXplorer 简要介绍 xBIM WeXplorer xViewer 基本应用 xBIM WeXplorer xViewer 浏览器检查 xBIM WeXplorer xV ...

  6. linux清屏命令(clear,reset)

    (1)clear 这个命令将会刷新屏幕,本质上只是让终端显示页向后翻了一页,如果向上滚动屏幕还可以看到之前的操作信息.一般都会用这个命令. (2)reset 这个命令将完全刷新终端屏幕,之前的终端输入 ...

  7. arm上电死机怎么烧写boot

    一般上电到死机还有一段时间,在这段时间完成,已经出现两次了.

  8. iframe父页面获取子页面的参数

    1.父页面中的iframe <iframe name="parentPage"></iframe> 2.子页面中元素的属性 <input type=& ...

  9. 解析XML的方法

    解析XML的方法 1.DOM生成和解析XML 2.SAX生成和解析XML 3.DOM4J生成和解析XML 4.JDOM生成和解析XML

  10. XmlDocument 转换为xml字符串

    static public string XMLDocumentToString(XmlDocument doc)     {         MemoryStream stream = new Me ...