表单验证&&常用正则


;(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. Java集合中的Map接口

    jdk1.8.0_144 Map是Java三种集合中的一种位于java.util包中,Map作为一个接口存在定义了这种数据结构的一些基础操作,它的最终实现类有很多:HashMap.TreeMap.So ...

  2. ASP.NET Core的身份认证框架IdentityServer4--(1)服务配置

    官网文档地址:点我点我 准备 创建一个名为IdentityServer的ASP.NET Core Web Api 项目,端口5000 创建一个名为Api的ASP.NET Core Web Api 项目 ...

  3. 情景linux—不曾了解的cat用法

    情景 cat是linux命令中最为基础的命令之一,它是"concatenate"(连接)的简写,作用概述是concatenate and print files,即:连接和查看文件 ...

  4. python网络编程基础知识整理

  5. 把mmapv1存储引擎存储的mongodb3.0数据库数据复制到WiredTiger存储引擎的mongodb3.2中

    mongodb3.0在mmapv1的存储引擎基础上添加了一个新的存储引擎WiredTiger.但是3.0的默认存储引擎依旧是mmapv1,因此我们项目之前也就用的默认方式. 但是mongodb更新实在 ...

  6. sublime Xdebug 配置

    Sublime Text 配置x-debug 配置php 的x-debug 拓展 下载地址 :http://www.xdebug.org/download.php 放到php ext的目录下 然后使用 ...

  7. 不解,排名靠前那么多的人为什么抄袭我的activit博文??

    刚才也是无意搜了下自己的最近发表的activiti系列博文,无意中发现居然在别人的csdn博客中也成了原创. ......

  8. R语言︱大数据集下运行内存管理

    在实操时出现以下的问题: Error: cannot allocate vector of size 2.9GB 大神指导(http://bbs.pinggu.org/thread-3682816-1 ...

  9. C#制表符过滤处理方法

    C#制表符过滤处理方法,动态替换字符串里面的制表符. /// <summary> /// Descrioption: ///需要替换字符集合,可参见MSDN /// The Trim me ...

  10. Linux显示工作路径

    Linux显示工作路径 youhaidong@youhaidong-ThinkPad-Edge-E545:~$ pwd /home/youhaidong