JS中常用的正则表达式


Posted in Javascript onSeptember 29, 2016

以下收录一些我经常用到的正则表达式,因为工作场景中用到正则的地方几乎都跟validate插件的验证有关系,所以以下正则也是$.validator.addMethod() 的拓展:

validate: http://jqueryvalidation.org/

电话验证

/**
 * 手机
 * */
$.validator.addMethod("isMobile", function (value, element) {
  var reg = /^((1[3-8][0-9])+\d{8})$/;
  return this.optional(element) || (reg.test(value));
}, "手机格式不正确");
/**
 * 号码,固话与手机都可以
 * */
jQuery.validator.addMethod("allPhone", function(v, e) {
    return this.optional(e) || /^(([0\+]\d{2,3}-)?(0\d{2,3})-)?(\d{7,8})(-(\d{3,}))?$/.test(v)||/^(1(([35][0-9])|(47)|[8][01236789]))\d{8}$/.test(v);},
  "请输入正确的号码:区号-电话号码/手机号");
/**
 * 固话、传真,传真格式与固话是一样的
 * */
jQuery.validator.addMethod("isTel", function(v, e) { return this.optional(e) || /^(([0\+]\d{2,3}-)?(0\d{2,3})-)?(\d{7,8})(-(\d{3,}))?$/.test(v);}, "请输入正确的电话号码");

数字验证

/**
 * 正整数
 * */
$.validator.addMethod("ispositivenum", function (value, element) {
  var reg = /^([0]|[1-9]\d*)$/;
  return this.optional(element) || (reg.test(value));
}, "请输入正整数");
/**
 * 正数(包括浮点数)
 * */
$.validator.addMethod("pFloatTwo", function (value, element) {
  return this.optional(element) || (/^([1-9]\d*|[0])(\.\d{1,2})?$/.test(value));
}, "请输入正数,最多保留两位小数");
/**
 * 价格(包括浮点数)最大值99999.99
 * */
$.validator.addMethod("price", function (value, element) {
  return this.optional(element) || (value>0&&(/^([1-9]\d{0,4}|[0])(\.\d{1,2})?$/.test(value)));
}, "请输入正数,最大值99999.99,最多保留两位小数");
/**
 * 规格
 * */
$.validator.addMethod("size", function (value, element) {
  var reg = /^[1-9]\d{0,4}$/;
  return this.optional(element) || (reg.test(value));
}, "请输入正整数,最大值99999");
/**
 * 数量
 * */
$.validator.addMethod("qty", function (value, element) {
  return this.optional(element) || (value>0 && (/^([1-9]\d{0,4}|[0])(\.\d{1,3})?$/.test(value)));
}, "请输入正数,最大值99999.999,最多保留三位小数");

车牌号码验证

/**
 * 车牌号码验证
 * */
$.validator.addMethod("isCarNo", function(value, element){
  var reg = /^[\u4e00-\u9fa5]{1}[a-zA-Z]{1}[a-zA-Z_0-9]{4}[a-zA-Z_0-9_\u4e00-\u9fa5]$|^[a-zA-Z]{2}\d{7}$ /;
  return this.optional(element) || (reg.test(value));
},"请输入正确的车牌号码,大小写不区分");

身份证号验证包括15位18位身份证验证

//身份证15位转18位中,计算校验位即最后一位
function GetVerifyBit(id){
  var result;
  var nNum=eval(id.charAt(0)*7+id.charAt(1)*9+id.charAt(2)*10+id.charAt(3)*5+id.charAt(4)*8+id.charAt(5)*4+id.charAt(6)*2+id.charAt(7)*1+id.charAt(8)*6+id.charAt(9)*3+id.charAt(10)*7+id.charAt(11)*9+id.charAt(12)*10+id.charAt(13)*5+id.charAt(14)*8+id.charAt(15)*4+id.charAt(16)*2);
  nNum=nNum%11;
  switch (nNum) {
    case 0 :
      result="1";
      break;
    case 1 :
      result="0";
      break;
    case 2 :
      result="X";
      break;
    case 3 :
      result="9";
      break;
    case 4 :
      result="8";
      break;
    case 5 :
      result="7";
      break;
    case 6 :
      result="6";
      break;
    case 7 :
      result="5";
      break;
    case 8 :
      result="4";
      break;
    case 9 :
      result="3";
      break;
    case 10 :
      result="2";
      break;
  }
  //document.write(result);
  return result;
}
/*
 功能:验证身份证号码是否有效
 提 示信息:未输入或输入身份证号不正确!
 使用:validateIdCard(obj,birthday,s)//s:1为男,0为女
 返回:0,1,2,3,4,5
 */
function validateIdCard(obj,birthday,s){
  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 strIDno = obj;
  if(birthday!=null){
    birthday = birthday.replace(/-/g,"/");
  }
  var idCardLength = strIDno.length;
  if(!/^\d{17}(\d|x)$/i.test(strIDno)&&!/^\d{15}$/i.test(strIDno)){
    return 1; //非法身份证号
  }
  if(aCity[parseInt(strIDno.substr(0,2))]==null){
    return 2;// 非法地区
  }
  // 15位身份证转换为18位
  if (idCardLength==15){
    sBirthday = "19" + strIDno.substr(6,2) + "-" + Number(strIDno.substr(8,2)) + "-" + Number(strIDno.substr(10,2));
    var d = new Date(sBirthday.replace(/-/g,"/"));
    var dd = d.getFullYear().toString() + "-" + (d.getMonth()+1) + "-" + d.getDate();
    var genderNo=strIDno.substr(14,1);
    if(sBirthday != dd){
      return 3; //非法生日
    }
    if(birthday==""){
      return 4;//您还没填写出生日期
    }
    if(birthday!=null && d.getTime()!=new Date(birthday).getTime()){
      return 5; //与出生日期不符
    }
    if(s!=null && s!=0 && s!=1){
      return 6;//您还没填写性别
    }
    if(s!=null && genderNo%2!=s){
      return 7;//与性别不符
    }
    strIDno=strIDno.substring(0,6)+"19"+strIDno.substring(6,15);
    strIDno=strIDno+GetVerifyBit(strIDno);
  }
  // 判断是否大于2078年,小于1900年
  var year =strIDno.substring(6,10);
  if (year<1900 || year>2078 ){
    return 3;//非法生日
  }
  /*if(){
   }*/
  //18位身份证处理
  //在后面的运算中x相当于数字10,所以转换成a
  strIDno = strIDno.replace(/x$/i,"a");
  sBirthday=strIDno.substr(6,4)+"-"+Number(strIDno.substr(10,2))+"-"+Number(strIDno.substr(12,2));
  var d = new Date(sBirthday.replace(/-/g,"/"));
  var genderNo=strIDno.substr(16,1);
  if(sBirthday!=(d.getFullYear()+"-"+ (d.getMonth()+1) + "-" + d.getDate())){
    return 3; //非法生日
  }
  if(birthday==""){
    return 4;//您还没填写出生日期
  }
  if(birthday!=null && d.getTime()!=new Date(birthday).getTime()){
    return 5; //与出生日期不符
  }
  if(s!=null && s!=0 && s!=1){
    return 6;//您还没填写性别
  }
  if(s!=null && genderNo%2!=s){
    return 7;//与性别不符
  }
  // 身份证编码规范验证
  for(var i = 17;i>=0;i --){
    iSum += (Math.pow(2,i) % 11) * parseInt(strIDno.charAt(17 - i),11);
  }
  if(iSum%11!=1){
    return 1;// 非法身份证号
  }
  // 判断是否屏蔽身份证
  var words = new Array();
  words = new Array("11111119111111111","12121219121212121");
  for(var k=0;k<words.length;k++){
    if (strIDno.indexOf(words[k])!=-1){
      return 1;
    }
  }
  return 0;
}
//身份证(无关联验证)
$.validator.addMethod("cretID", function(value, element, param){
  var n=validateIdCard(value);
  var error=["","非法身份证号","地区编号不合法","出生日期不合法"];
  param[1]=error[n];
  return this.optional(element) || n==0;
},$.validator.format("{1}"));

以上所述是小编给大家介绍的JS中常用的正则表达式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JQuery textlimit 显示用户输入的字符数 限制用户输入的字符数
May 14 Javascript
使用 Node.js 做 Function Test实现方法
Oct 25 Javascript
百度判断手机终端并自动跳转js代码及使用实例
Jun 11 Javascript
JavaScript中的冒泡排序法
Aug 03 Javascript
JS简单获取客户端IP地址的方法【调用搜狐接口】
Sep 05 Javascript
vue.js父组件使用外部对象的方法示例
Apr 25 Javascript
微信小程序 支付功能(前端)的实现
May 24 Javascript
JS奇技之利用scroll来监听resize详解
Jun 15 Javascript
JavaScript方法_动力节点Java学院整理
Jun 28 Javascript
JavaScript函数apply()和call()用法与异同分析
Aug 10 Javascript
Vue实现跑马灯效果
May 25 Javascript
vue组件中传值EventBus的使用及注意事项说明
Nov 16 Javascript
JS 事件绑定、事件监听、事件委托详细介绍
Sep 28 #Javascript
js创建对象几种方式的优缺点对比
Sep 28 #Javascript
AngularJS表单验证中级篇(3)
Sep 28 #Javascript
微信公众号 客服接口的开发实例详解
Sep 28 #Javascript
jQuery解析XML 详解及方法总结
Sep 28 #Javascript
iOS和Android用同一个二维码实现跳转下载链接的方法
Sep 28 #Javascript
微信小程序 实例应用(记账)详解
Sep 28 #Javascript
You might like
一个简单实现多条件查询的例子
2006/10/09 PHP
PHP的foreach中使用引用时需要注意的一个问题和解决方法
2014/05/29 PHP
PHP代码维护,重构变困难的4种原因分析
2016/01/25 PHP
腾讯的ip接口 方便获取当前用户的ip地理位置
2010/11/25 Javascript
jQuery的运行机制和设计理念分析
2011/04/05 Javascript
30个最佳jQuery Lightbox效果插件分享
2011/04/11 Javascript
判断滚动条到底部的JS代码
2013/11/04 Javascript
javascript 中that的含义示例介绍
2014/05/14 Javascript
javascript结合Canvas 实现简易的圆形时钟
2015/03/11 Javascript
AngularJS模块学习之Anchor Scroll
2016/01/19 Javascript
jQuery 检查某个元素在页面上是否存在实例代码
2016/10/27 Javascript
AngularJS基于ngInfiniteScroll实现下拉滚动加载的方法
2016/12/14 Javascript
jQueryMobile之窗体长内容的缺陷与解决方法实例分析
2017/09/20 jQuery
浅析Node.js非对称加密方法
2018/01/29 Javascript
利用Vue构造器创建Form组件的通用解决方法
2018/12/03 Javascript
js屏蔽退格键(backspace或者叫后退键与F5)
2019/02/10 Javascript
ES2020系列之空值合并运算符 '??'
2020/07/22 Javascript
浅谈numpy中linspace的用法 (等差数列创建函数)
2017/06/07 Python
python实现自动发送邮件发送多人、群发、多附件的示例
2018/01/23 Python
Python FTP两个文件夹间的同步实例代码
2018/05/25 Python
Python爬取qq空间说说的实例代码
2018/08/17 Python
使用Python opencv实现视频与图片的相互转换
2019/07/08 Python
python使用rsa非对称加密过程解析
2019/12/28 Python
Python Django搭建网站流程图解
2020/06/13 Python
python中用ctypes模拟点击的实例讲解
2020/11/26 Python
深入理解Python变量的数据类型和存储
2021/02/01 Python
css3加js做一个简单的3D行星运转效果实例代码
2017/01/18 HTML / CSS
美国儿童运动鞋和服装零售商:Kids Foot Locker
2017/08/05 全球购物
馥蕾诗美国官网:Fresh美国
2019/10/09 全球购物
德国二手设计师时装和复古时装跳蚤市场:Mädchenflohmarkt
2020/11/09 全球购物
Linux如何命名文件--使用文件名时应注意
2014/05/29 面试题
电脑销售顾问自荐信
2014/01/29 职场文书
医院护士党的群众路线教育实践活动对照检查材料思想汇报
2014/10/04 职场文书
2014年人事行政工作总结
2014/12/03 职场文书
留学推荐信中文范文
2015/03/26 职场文书
信息简报范文
2015/07/21 职场文书