常用表单验证&&常用正则
表单验证&&常用正则
;(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;
}
})();
常用表单验证&&常用正则的更多相关文章
- 一个PHP常用表单验证类(基于正则)
一个基于正则表达式的PHP常用表单验证类,作者:欣然随风.这个表单判断类的功能有:验证是否为指定长度的字母/数字组合.验证是否为指定长度汉字.身 份证号码验证.是否是指定长度的数字.验证邮件地址.电话 ...
- php常用表单验证类用法实例
<?php /** * 页面作用:常用表单验证类 * 作 者:欣然随风 * QQ:276624915 */ class class_post { //验证是否为指定长度的字母/数字组合 func ...
- iview表单验证之正则验证、函数验证
iview表单验证之正则 正则验证: 代码: loginRules: { stringLength: [ { required: true, message: '该字段不能为空', trigger: ...
- JavaScript常用表单验证正则表达式(身份证、电话号码、邮编、日期、IP等)
身份证正则表达式 //身份证正则表达式(15位)isIDCard1=/^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$/;//身份证正则表达式 ...
- 前端表单验证常用的15个JS正则表达式
在表单验证中,使用正则表达式来验证正确与否是一个很频繁的操作,本文收集整理了15个常用的javaScript正则表达式,其中包括用户名.密码强度.整数.数字.电子邮件地址(Email).手机号码.身份 ...
- 表单验证常用的JS正则表达式
在表单验证中,使用正则表达式来验证正确与否是一个很频繁的操作,本文收集整理了15个常用的javaScript正则表达式,其中包括用户名.密码强度.整数.数字.电子邮件地址(Email).手机号码.身份 ...
- JavaScript---网络编程(12)--DHTML技术演示(5)-form表单验证技术(正则)
这里不进行很复杂的后台验证以及JavaScript的正则表达式,只是简单的介绍下这个技术,简单的后台接收与跳转,大概了解怎么验证的就可以.具体的技术,我后面还会继续写博客的.本人也还在学习中. 表单验 ...
- js实现表单验证 常用JS表单验证
CSS代码 @charset "gb2312"; /* CSS Document */ body,dl,dt,dd,div,form {padding:;margin:;} #he ...
- 关于JS中的常用表单验证+正则表达式
一.非空验证 trim:去空格(去掉前后的空格),任何字符串都可以用这个方法.写法为:if(v.trim().length==0),表示如果去掉空格后的字符串的长度为0. <body> & ...
随机推荐
- jquery toggle 方法被废除的替代方法
今天使用 toggle 方法的时候,该方法一直不能生效. 原来jquery 的引入文件是1.9,该方法在1.8以上已被废除. 那么简单的切换状态,我们可使用if 语句进行代替 如下: 记录一开始设置隐 ...
- CSS布局(二) 盒子模型属性
盒子模型的属性 宽高width/height 在CSS中,可以对任何块级元素设置显式高度. 如果指定高度大于显示内容所需高度,多余的高度会产生一个视觉效果,就好像有额外的内边距一样: 如果指定高度小于 ...
- Navi.Soft31.产品.微信聊天(永久免费)
1系统简介 1.1功能简述 微信确实是一款优秀的社交的软件,被越来越多的人使用.它的电脑版最新版本是2.6,更新也比较及时,只是它有一个功能差强人意,就是同一台电脑只能运行一个微信号,不知道为何这样设 ...
- P2P技术如何将实时视频直播带宽降低75%?
本文内容来自学霸君资深架构师袁荣喜的技术分享. 1.前言 实时视频直播经过去年的千播大战后已经成为互联网应用的标配技术,但直播平台的成本却一直居高不下,各个平台除了挖主播.挖网红以外,其背后高额的带宽 ...
- win10外接键盘失灵
故障描述:笔记本外接的键盘突然之间就失灵,键盘的灯不亮,无法输入 处理方程: 1. 我的电脑右击--> 管理 --> 设备管理器(开始失灵时,键盘下的HID Keyboard Device ...
- LeetCode第二天&第三天
leetcode 第二天 2017年12月27日 4.(118)Pascal's Triangle JAVA class Solution { public List<List<Integ ...
- php程序员的成长之路
第一阶段:基础阶段(基础PHP程序员) 重点:把LNMP搞熟练(核心是安装配置基本操作) 目标:能够完成基本的LNMP系统安装,简单配置维护:能够做基本的简单系统的php开发:能够在PHP中型系统中支 ...
- Spark SQL1.2测试
Spark SQL 1.2 运行原理 case class方式 json文件方式 背景:了解到HDP也能够支持Spark SQL,但官方文档是版本1.2,希望支持传统数据库.hadoop平台.文本格式 ...
- VS2005 添加lib 的方法
应用程序使用外部库时需要进行加载,两种库的加载本质上都是一样:提供功能和功能的定义.vs2005 c++ 项目设置外部库方法如下:1. 添加编译所需要(依赖)的 lib 文件 在"项 ...
- return *this 与return this的区别
return *this返回当前对象的引用(也就是返回当前对象) return this返回当前对象的地址. #include <iostream> using namespace std ...