在这篇文章里,我已经编写了12个超有用的正则表达式,这可是WEB开发人员的最爱哦。 1.在input框中只能输入金额,其实就是只能输入最多有两位小数的数字 //第一种在input输入框限制 <input type="text" m

在这篇文章里,我已经编写了12个超有用的正则表达式,这可是WEB开发人员的最爱哦。

1.在input框中只能输入金额,其实就是只能输入最多有两位小数的数字

  1. //第一种在input输入框限制
  2. <input type="text" maxlength="8" class="form-control" id="amount" style="margin-right: 2px;" value="" onChange="count();" onkeyup="if (this.value==this.value2) return; if (this.value.search(/^\d*(?:\.\d{0,2})?$/)==-1) this.value=(this.value2)?this.value2:'';else this.value2=this.value;">元
  3. //第二种对于表单动态增加的方式,只能在js方法中验证。
  4. var amount=$("#amount").val();
  5. if (amount.search(/^\d*(?:\.\d{0,2})?$/)==-1) {
  6. alert("金额格式不对,最多有两位小数");
  7. return false;
  8. }
复制

2.验证邮箱格式

  1. var reg=/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/;
  2. var email=$("#email").val();
  3. if(!reg.test(email) ){
  4. alert("请输入符合规范的邮箱账号!");
  5. return false;
  6. }
复制

3.密码采用数字、字母、特殊字符且长度为8-20位 

  1. function validatePwd(str) {
  2. if (/^.*?[\d]+.*$/.test(str) && /^.*?[A-Za-z]/.test(str)
  3. && /^.*?[~/`!@#$%^&*()_+|{}?;:><\-\]\\[\/].*$/.test(str) && /^.{8,20}$/.test(str)) {
  4. return true;
  5. }
  6. return false;
  7. }
复制

4.验证电话号码

  1. /**
  2. * 验证电话号码
  3. * @param phoneValue 要验证的电话号码
  4. * @returns 匹配返回true 不匹配返回false
  5. */
  6. function validatePhone(phoneValue) {
  7. phoneValue = valueTrim(phoneValue);
  8. var reg = /^[1][0-9]{10}$/;
  9. return reg.test(phoneValue);
  10. }
复制

5.判断是否是汉字

  1. /**
  2. * 判断是否是汉字
  3. *
  4. * @param charValue
  5. * 要验证的数据
  6. * @returns 匹配返回true 不匹配返回false
  7. */
  8. function isCharacter(charValue) {
  9. var reg = /^[\u4e00-\u9fa5]{0,}$/;
  10. return reg.test(charValue);
  11. }
复制

6.是否为字母:true:是,false:不是

  1. function isChar(charValue){
  2. var charPattern=/^[a-zA-Z]*$/; //是否为字母
  3. result=charPattern.test(charValue);
  4. return result;
  5. }
复制

7.判断是否为数字

  1. function isNum(numValue){
  2. var numPattern=/^\d*$/; //数字的正则表达式
  3. result=numPattern.test(numValue);
  4. return result;
  5. }
复制

8.整数的正则表达式

  1. function isInt(intValue){
  2. var intPattern=/^0$|^[1-9]\d*$/; //整数的正则表达式
  3. result=intPattern.test(intValue);
  4. return result;
  5. }
复制

9.是否为字母和数字

  1. function isCharNum(flagValue){
  2. var flagPattern=/^[a-zA-Z0-9]*$/; //是否为字母和数字
  3. result=flagPattern.test(flagValue);
  4. return result;
  5. }
复制

10.检验18位身份证号码 

  1. /**
  2. * 检验18位身份证号码(15位号码可以只检测生日是否正确即可,自行解决)
  3. *
  4. * @param idCardValue
  5. * 18位身份证号
  6. * @returns 匹配返回true 不匹配返回false
  7. */
  8. function idCardVildate(cid) {
  9. var arrExp = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ];// 加权因子
  10. var arrValid = [ 1, 0, "X", 9, 8, 7, 6, 5, 4, 3, 2 ];// 校验码
  11. var reg = /^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/;
  12. if (reg.test(cid)) {
  13. var sum = 0, idx;
  14. for (var i = 0; i < cid.length - 1; i++) {
  15. // 对前17位数字与权值乘积求和
  16. sum += parseInt(cid.substr(i, 1), 10) * arrExp[i];
  17. }
  18. // 计算模(固定算法)
  19. idx = sum % 11;
  20. // 检验第18为是否与校验码相等
  21. return arrValid[idx] == cid.substr(17, 1).toUpperCase();
  22. } else {
  23. return false;
  24. }
  25. }
复制

11.验证15位数身份证号码中的生日是否是有效生日

  1. function isValidityBrithBy15IdCard(idCard15) {
  2. var year = idCard15.substring(6, 8);
  3. var month = idCard15.substring(8, 10);
  4. var day = idCard15.substring(10, 12);
  5. var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day));
  6. // 对于老身份证中的你年龄则不需考虑千年虫问题而使用getYear()方法
  7. if (temp_date.getYear() != parseFloat(year)
  8. || temp_date.getMonth() != parseFloat(month) - 1
  9. || temp_date.getDate() != parseFloat(day)) {
  10. return false;
  11. } else {
  12. return true;
  13. }
  14. }
复制

12.验证18位数身份证号码中的生日是否是有效生日

  1. function isValidityBrithBy18IdCard(idCard18) {
  2. var year = idCard18.substring(6, 10);
  3. var month = idCard18.substring(10, 12);
  4. var day = idCard18.substring(12, 14);
  5. var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day));
  6. // 这里用getFullYear()获取年份,避免千年虫问题
  7. if (temp_date.getFullYear() != parseFloat(year)
  8. || temp_date.getMonth() != parseFloat(month) - 1
  9. || temp_date.getDate() != parseFloat(day)) {
  10. return false;
  11. } else {
  12. return true;
  13. }
  14. }
复制

这就是小编整理的web开发中常用的表单验证的正则表达式,希望大家喜欢。

12个常用的js正则表达式的更多相关文章

  1. JS表单验证-12个常用的JS表单验证

    JS表单验证-12个常用的JS表单验证 最近有个项目用到了表单验证,小编在项目完结后的这段时间把常用的JS表单验证demo整理了一下,和大家一起分享~~~ 1. 长度限制 <p>1. 长度 ...

  2. 用户名、密码等15个常用的js正则表达式

    本文收集整理了15个常用的javaScript正则表达式,其中包括用户名.密码强度.整数.数字.电子邮件地址(Email).手机号码.身份证号.URL地址. IPv4地址. 十六进制颜色. 日期. Q ...

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

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

  4. 常用的js正则表达式

    正则表达式,一个十分古老而又强大的文本处理工具,仅仅用一段非常简短的表达式语句,便能够快速实现一个非常复杂的业务逻辑.熟练地掌握正则表达式的话,能够使你的开发效率得到极大的提升. 下面是一些,在前端开 ...

  5. 【转】17种常用的JS正则表达式 非负浮点数 非负正数.

    <input type='text' id='SYS_PAGE_JumpPage' name='SYS_PAGE_JumpPage' size='3' maxlength='5' onkeyup ...

  6. 八个常用的js正则表达式

    开篇:开发中如果有input输入框,难免就要写正则表达式,因此在这里总结了一些常见常用的正则表达式的书写方法,希望会大家有所帮助: 附图: 一.手机号码 $(document).ready(funct ...

  7. 03_常用的JS正则表达式54种形式类型

    1.由数字.26个英文字母或者下划线组成的字符串: ^[0-9a-zA-Z_]{1,}$ 2.非负整数(正整数 + 0 ): ^/d+$ 3. 正整数: ^[0-9]*[1-9][0-9]*$ 4.非 ...

  8. 17种常用的JS正则表达式 非负浮点数 非负正数

    <input type='text' id='SYS_PAGE_JumpPage' name='SYS_PAGE_JumpPage' size='3' maxlength='5' onkeyup ...

  9. 用户名、密码、整数等常用的js正则表达式

    1 用户名正则 //用户名正则,4到16位(字母,数字,下划线,减号) var uPattern = /^[a-zA-Z0-9_-]{4,16}$/; //输出 true console.log(uP ...

随机推荐

  1. 实验五实验报告 20135324&&20135330

    北京电子科技学院(BESTI) 实验报告 课程:深入理解计算机系统 班级:1353 姓名:张若嘉 杨舒雯 学号:20135330 20135324 成绩: 指导教师:娄嘉鹏 实验日期:2015.11. ...

  2. pythonchallenge(二)

    PythonChallenge_2 一.实验说明 1. 环境登录 无需密码自动登录,系统用户名shiyanlou,密码shiyanlou 2. 环境介绍 本实验环境采用带桌面的Ubuntu Linux ...

  3. Javascript的字面量对象以及如何拆解字面量对象

    简单的说,字面量对象提供了一直非常方便构建新对象的方式,它的格式非常简单且容易阅读.是大多数前端程序员在构建对象时比较推崇的一种方式. 格式: var person = { name : " ...

  4. 浅入ARP

    1.ARP的工作原理 IP层协议ARP的核心功能就是通过目的主机IP地址得到主机的硬件地址,然后通过硬件地址进行通信.和计算机网络中的很多技术一样,ARP协议也是使用了建立一个缓存表的思想.它规定每个 ...

  5. Node基础:资源压缩之zlib

    概览 做过web性能优化的同学,对性能优化大杀器gzip应该不陌生.浏览器向服务器发起资源请求,比如下载一个js文件,服务器先对资源进行压缩,再返回给浏览器,以此节省流量,加快访问速度. 浏览器通过H ...

  6. Bootstrap系列 -- 27. 下拉菜单对齐方式

    Bootstrap框架中下拉菜单默认是左对齐,如果你想让下拉菜单相对于父容器右对齐时,可以在“dropdown-menu”上添加一个“pull-right”或者“dropdown-menu-right ...

  7. [USACO2003][poj2185]Milking Grid(kmp的next的应用)

    题目:http://poj.org/problem?id=2185 题意:就是要求一个字符矩阵的最小覆盖矩阵,可以在末尾不完全重合(即在末尾只要求最小覆盖矩阵的前缀覆盖剩余的尾部就行了) 分析: 先看 ...

  8. [C#]Attribute特性(2)——方法的特性及特性参数

    上篇博文[C#]Attribute特性介绍了特性的定义,类的特性,字段的特性,这篇博文将介绍方法的特性及特性参数相关概念. 3.方法的特性 之所以将这部分单列出来进行讨论,是因为对方法的特性查询的反射 ...

  9. 第四十六课:MVC和MVVM的开发区别

    实现MVC的目的就是为了让M和V相分离.前端的MVC无法做到View和Model的相分离,而MVVM可以. 我们先来看一个用MVC模式开发的经典例子:(一定要深入了解这种开发的思想,而不是看懂代码) ...

  10. Symfony启动过程详细学习

    想了解symfony的启动过程,必须从启动文件(这里就以开发者模式)开始. <?php /* * web/app_dev.php */ $loader = require_once __DIR_ ...