JavaScript学习笔记- 正则表达式常用验证
<div>
<h1>一、判断中国邮政编码匹配</h1>
<p>分析:中国邮政编码都是6位,且为纯数字</p>
<div>邮政编码:<input id="Postcode" type="text" onblur="checkPost();" /></div>
<div id="Prompt"></div>
</div>
<script type="text/javascript">
function checkPost() {
var Post = document.getElementById("Postcode").value; //获取输入框的值
var Prom = document.getElementById("Prompt"); //获取提示栏
var regPost = /^\d{6}$/; //解释:匹配数字6次,且开头到结尾都为数字
var isPost = regPost.test(Post); //测试 Post 是否符合 regPost 的规则,是则返回true,不是则返回false
if (isPost == false) {
Prom.innerHTML = "请输入正确的邮政编码";
return false;
}
Prom.innerHTML = "";
return true;
}
</script>
<div>
<h1>一、判断中国手机号</h1>
<p>分析:中国手机号都是11位,且为纯数字</p>
<div>手机号:<input id="Mobile" type="text" onblur="checkMobile();" /></div>
<div id="PromptM"></div>
</div>
<script type="text/javascript">
function checkMobile() {
var Mobile = document.getElementById("Mobile").value; //获取输入框的值
var PromM = document.getElementById("PromptM"); //获取提示栏
if (Mobile.length != 11) { //首先判断其必须为11位
PromM.innerHTML = "请输入11位手机号";
return false
}
/**分析:
* 手机号码:
* 13[0-9], 14[5,7], 15[0, 1, 2, 3, 5, 6, 7, 8, 9], 17[0, 1, 6, 7, 8], 18[0-9]
* 移动号段: 134,135,136,137,138,139,147,150,151,152,157,158,159,170,178,182,183,184,187,188
* 联通号段: 130,131,132,145,152,155,156,170,171,176,185,186
* 电信号段: 133,134,153,170,177,180,181,189
分析是在度娘里搜的,随便一搜就出来了很多了,这是2016年最新的
**/ var regMobile = /^1(3[0-9]|4[57]|5[0-35-9]|7[01678]|8[0-9])\d{8}$/;
/**解释:
* ^1 开头为1
* 3[0-9] 第二位为3,第三位为0-9中的任意数字
* |4[57] 或第二位为4,第三位为5或7
* |5[0-35-9] 或第二位为5,第三位为0-3 5-9中的任意数字
* |7[01678] 或第二位为7,第三位为[...]中的任意数字
* |8[0-9] 或第二位为8,第三位为0-9中的任意数字
* \d{8}$ 后8为纯数字
**/
var isMobile = regMobile.test(Mobile);
if (isMobile == false) {
PromM.innerHTML = "请输入正确的手机号";
return false;
}
PromM.innerHTML = "";
return true;
}
</script>
<div>
<h1>一、判断用户名</h1>
<p>分析:用户名每个平台的规定不一样,这里按“英文字母和数字组成的4-18为字符,以字母开头”为例</p>
<div>用户名:<input id="UseName" type="text" onblur="checkUseN();" /></div>
<div id="PromptU"></div>
</div>
<script type="text/javascript">
function checkUseN() {
var UseN = document.getElementById("UseName").value; //获取输入框的值
var PromU = document.getElementById("PromptU"); //获取提示栏
if (UseN == "") { //判断用户名不为空
PromU.innerHTML = "用户名不能为空"
return false;
}
var regUseN = /^[A-z][A-z0-9]{3,17}$/;
/**解释:
* ^[A-z] 以字母开头
* [A-z0-9] 后面最少4位字母或数字,最多17个,且以此为结尾
**/
var isUseN = regUseN.test(UseN);
if (isUseN == false) {
PromU.innerHTML = "请输入正确的用户名";
return false;
}
PromU.innerHTML = "";
return true;
}
</script>
<div>
<h1>一、判断密码</h1>
<p>分析:密码每个平台的规则也不尽相同,这里按“英文字母+数字+特殊符号的6-20位字符组成”为例</p>
<div>密码:<input id="password" type="password" onblur="checkPW();" /></div>
<div id="PromptPW"></div>
<div>确认密码:<input id="againpw" type="password" onblur="checkApw();" /></div>
<div id="PromptApw"></div> </div>
<script type="text/javascript">
var PW;
function checkPW() {
PW = document.getElementById("password").value; //获取密码输入框的值
var PromPW = document.getElementById("PromptPW"); //获取提示栏
if (PW == "") { //判断密码不为空
PromPW.innerHTML = "密码不能为空"
return false;
}
if (PW.length < 6) { //判断密码长度最少6位
PromPW.innerHTML = "密码最少为6位字符"
return false;
}
if (PW.length > 20) { //判断密码长度最多20位
PromPW.innerHTML = "密码最多只可以20位字符";
return false;
}
var zm = /[A-z]/g //全局查找字母
if (zm.test(PW) == false) {
PromptPW.innerHTML = "密码必须包含至少一位字母"
return false;
}
var NaN = /\d/g //全局查找数字
if (NaN.test(PW) == false) {
PromptPW.innerHTML = "密码必须包含至少一位数字"
return false;
}
var fh = /[^A-z]\D/g //全局查找非数字与除了字母之外的字符
if (fh.test(PW) == false) {
PromptPW.innerHTML = "密码必须包含至少一位字符"
return false;
}
PromptPW.innerHTML = ""
return true;
} function checkApw() {
var Apw = document.getElementById("againpw").value; //获取确认密码输入框值
var PromApw = document.getElementById("PromptApw"); //获取提示栏
if (Apw == "") { //判断确认密码不为空
PromApw.innerHTML = "确认密码不能为空"
return false;
}
if (Apw !== PW) { //判断确认密码值与密码值必须是否一致
PromApw.innerHTML = "两次输入的密码不一致";
return false;
}
PromApw.innerHTML = "";
return true;
}
</script>
<div>
<h1>一、判断电子邮件</h1>
<p>分析:888@qq.com 888@sina.com.cn</p>
<div>E-mail:<input id="email" type="text" onblur="checkEm();" /></div>
<div id="PromptEm"></div>
</div>
<script type="text/javascript">
function checkEm() {
var Em = document.getElementById("email").value; //获取E-mail输入框值
var PromEm = document.getElementById("PromptEm"); //获取提示栏
var regEm = /^[a-zA-Z0-9_-]{1,}@[a-zA-Z0-9_-]{1,}(\.[a-zA-Z]{2,}){1,2}$/;
/**解释
* ^[a-zA-Z0-9_-]{1,} 开头可以是字母、数字或“_-”,且1次以上
* @[a-zA-Z0-9_-]{1,} 接着是“@”,“@”后是可以是字母、数字或“_-”,且字母、数字或“_-”要1次以上
* (\.[a-zA-Z]{2,}) 接着后面应该是“.”,“.”后应为字母,且字母需2次以上
* {1,2} 像上面这种“.”后面是字母的,最少1次 ,最多只能2次
**/
var isEm = regEm.test(Em);
if (isEm == false) {
PromEm.innerHTML = "您输入的E-mail地址不合法"
return false;
}
PromEm.innerHTML = "";
return true;
}
</script>
<div>
<h1>一、判断出生年月日</h1>
<p>分析:1997-05-11 19970511 1997-5-2</p>
<div>出生年月:<input id="Birth" type="text" onblur="checkBth()" /></div>
<div id="PromptBth"></div>
</div>
<script type="text/javascript">
function checkBth() {
var Bth = document.getElementById("Birth").value; //获取出生年月日输入框值
var PromBth = document.getElementById("PromptBth"); //获取提示栏 //首先大体判断下是否为正确的年月日格式
var regBth = /(19\d{2}|200\d{1}|201\d{1})-?(0?[1-9]|1[0-2])-?(0?[1-9]|[1-2]\d|3[0-1])/;
/**解释
* (19\d{2}|200\d{1}|201\d{1}) 匹配年份,
* 目前能有的年份开头仅有19xx也就是/19\d{2}/ || 200x也就是/200\d{1}/ || 201x也就是/201\d{1}/
* -? 可以有-,也可以没有
* 这是为符合大部分人的书写习惯,我们加上这个判断,可以让匹配率更高,用户体验也更好
* (0?[1-9]|1[0-2]) 匹配月份,这里的0?与上面的-?是一样的作用
*(0?[1-9]|[1-2]\d|3[0-1]) 匹配日
**/
var isBth = regBth.test(Bth);
if (isBth == false) {
PromBth.innerHTML = "请输入正确的出生年月";
return false;
} //判断瑞年平年,大小月的年月日格式
var YearR = /(19\d{2}|200\d{1}|201\d{1})/.exec(Bth)[0] / 4; //获取年份除以4,为判断是否为瑞平年
var YearZ = parseInt(YearR); //年份除以4取整,为判断是否为瑞平年
var month = /^(19\d{2}|200\d{1}|201\d{1})-?(0?[1-9]|1[0-2])/.exec(Bth)[0]; //获取年月 if (/2$/.test(month) == true) { //判断月份是否为2月
if (YearR == YearZ) { //判断是否为瑞年
if (/[30-31]$/.test(Bth) == true) { //判断是否有30或31
PromBth.innerHTML = "请输入正确的出生年月";
return false;
}
}
else if (YearR !== YearZ) { //判断是否为平年
if (/(29|30|31)$/.test(Bth) == true) { //判断是否有29或30或31
PromBth.innerHTML = "请输入正确的出生年月";
return false;
}
}
}
if (/(4|6|9|11)$/.test(month) == true) { //判断月份是否为4、6、9或11月
if (/31$/.test(Bth) == true) { //判断是否有31
PromBth.innerHTML = "请输入正确的出生年月";
return false;
}
}
PromBth.innerHTML = "";
return true;
}
</script>
作者:leona
JavaScript学习笔记- 正则表达式常用验证的更多相关文章
- JavaScript学习笔记- 正则表达式常用字符集及方法
正则表达式修饰符(修饰符 可以在全局搜索中不区分大小写) i(ignoreCase)执行对大小写不敏感的匹配 g (global) 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止) m( ...
- JavaScript学习笔记-正则表达式(语法篇)
正则表达式的模式规则是由一个字符系列组成的,包括所有字母和数字在内;大多数的字符(所有字母和数字)都是按字符的直接量来描述带匹配的字符;一些具有特殊语义的字符按照其特殊语义来进行匹配,有些字符需要通过 ...
- JavaScript学习笔记-正则表达式(RegExp对象)
正则表达式(RegExp对象) 1.正则表达式字面量,在脚本加载后编译.若你的正则表达式是常量,使用这种方式可以获得更好的性能,重复使用时不会重新编译: 2.使用构造函数创建的RegExp,提供了 ...
- Javascript学习笔记四——操作表单
Javascript学习笔记 大多网页比如腾讯,百度云之类的需要登陆,用户输入账号密码就可以登陆,那么浏览器是如何获取用户的输入的呢?今天就记录一下操作表单. 操作表单与操作DOM是差不多的,表单本身 ...
- javascript学习笔记(四) Number 数字类型
数字格式化方法toFixed().toExponential().toPrecision(),三个方法都四舍五入 toFixed() 方法指定小数位个数 toExponential() 方法 用科学 ...
- JavaScript学习笔记[0]
JavaScript学习笔记[0] 使用的是廖雪峰JavaScript教程. 数据类型 Number 表示数字,不区分浮点整形. === 比较时不转化数据类型. == 反之. NaN与任何值都不想等, ...
- JavaScript:学习笔记(5)——箭头函数=>以及实践
JavaScript:学习笔记(5)——箭头函数=>以及实践 ES6标准新增了一种新的函数:Arrow Function(箭头函数).本文参考的链接如下: MDN箭头函数:https://dev ...
- Javascript学习笔记三——操作DOM(二)
Javascript学习笔记 在我的上一个博客讲了对于DOM的基本操作内容,这篇继续巩固一下对于DOM的更新,插入和删除的操作. 对于HTML解析的DOM树来说,我们肯定会时不时对其进行一些更改,在原 ...
- Javascript学习笔记二——操作DOM
Javascript学习笔记 DOM操作: 一.GetElementById() ID在HTML是唯一的,getElementById()可以定位唯一的一个DOM节点 二.querySelector( ...
随机推荐
- MaskedTextBox的聚焦和光标位置
遇到一个关于MaskedTextBox聚焦和光标居左的问题. ①. 先说说聚焦: 起初给MaskedTextBox设置了Focus(),运行之后,并没有作用. 然后又给Form添加了Load事件,又设 ...
- ubuntu14.04下的NVIDIA Tesla K80显卡驱动的安装教程
搞深度学习如何能够不与浑身是“核”的显卡打交道呢? 人工智能的兴起除了数据量的大量提升,算法的不断改进,计算能力的逐步提高,还离不开软件基础设施的逐步完善.当下的主流的深度学习工具软件无论是Caffe ...
- 图灵机器人(问答机器人)API调用示例
问答机器人API文档:https://www.juhe.cn/docs/api/id/112 先上图: 说下大致实现的步骤: 1.首先使用了聚合数据的sdk,这样免费使用的数目可以多一些 2.使用gs ...
- CF 676B Pyramid of Glasses[模拟]
B. Pyramid of Glasses time limit per test 1 second memory limit per test 256 megabytes input standar ...
- 第5章 绘图基础_5.1-5.4 GDI绘图
5.1 GDI的原理和结构 (1)提供一种特殊机制彻底隔离应用程序与不同输出设备(eg.显示器或打印机),以便支持 与设备无关的图形. 光栅设备(如显示器.激光打印机):图像是由点构成的矩阵 图形输出 ...
- Unity3D中Update()与FixedUpdate()的区别
Unity3D中Update()与FixedUpdate()的区别是什么呢?从字面上理解,它们都是在更新时会被调用,并且会循环的调用.但是Update会在每次渲染新的一帧时,被调用.而FixedUpd ...
- windows 如何查看端口占用情况?
原文来自:http://www.iteye.com/topic/1117270 开始--运行--cmd 进入命令提示符 输入netstat -ano 即可看到所有连接的PID 之后在任务管理器中找到这 ...
- CSS3边框图片属性---border-image
#div{ border:18px solid; border-image:url("http://img.mukewang.com/52e22a1c0001406e03040221.jpg ...
- sg函数与博弈论2
参考链接: http://blog.sina.com.cn/s/blog_51cea4040100h3l9.html 这篇主要就是讲anti-sg.multi-sg和every-sg的. 例1 poj ...
- css实现省略号
样式: {width: 160px; overflow: hidden; text-overflow:ellipsis; white-space: nowrap;} 说明: white-space: ...