js 常用的正则表达式
以下收录一些我经常用到的正则表达式,因为工作场景中用到正则的地方几乎都跟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}"));
仅允许输入两位小数的整数
var onlyNum = function(num) {
var reg1 = /[^\d.]/g; //清除数字和“.” 以外的字符
var reg2 = /(\.\d*)\./g; //清除两个以上的"."
var reg3 = /^(\d+)\.(\d{0,2}).*$/; //清除两位以上的小数 var num2 = num.replace(reg1,"")
.replace(reg2,"$1")
.replace(reg3,"$1.$2");
return num2;
};
实际应用场景: 类似于京东购物车的数量输入框
$(".num_box").on("keyup",".num",function(){
var val = $(this).val();
var val2 = onlyNum(val);
$(this).val(val2)
}); 测试方案:(只要更改num的值,就能分布看到结果);
var num = "7.0.5..65.3";
var reg1 = /[^\d.]/g; //清除数字和“.” 以外的字符
var reg2 = /(\.\d*)\./g; //清除两个以上的"."
var reg3 =/^(\d+)\.(\d{0,2}).*$/; //清除两位以上的小数
var rel = num.match(reg1);
var result = num.replace(reg1,'');
console.log(result,rel); var rel2 = result.match(reg2);
var result2 = result.replace(reg2,'$1');
console.log(result2,rel2,RegExp.$1); var rel3 = result2.match(reg3);
var result3 = result2.replace(reg3,'$1.$2');
console.log(result3,rel3,RegExp.$1);
手机号码替换中间4位为**号
var mobile="15501854016";
var new = mobile.replace(/(^\d{3})\d{4}(\d{4}$)/,"$1****$2");//155****4016 //如果要取银行卡号若干位也是这个道理
利用正则批量替换文件中的路径(最好是使用ideaj 这种带有批量替换功能的编辑器)
var href= '<a class="link2" href="/login/forget/step1.html?loginType=${loginType}">忘记密码</a>'
var reg = /href=("|')/ /*查找href开头的文字*/
var res = val.replace(reg,"href=$1/v2") //例如我要在原来的路径前面加上v2层 '<a class="link2" href="/v2/login/forget/step1.html?loginType=${loginType}">忘记密码</a>'
js 常用的正则表达式的更多相关文章
- php 或js 常用的正则表达式
1. 平时做网站经常要用正则表达式,下面是一些讲解和例子,仅供大家参考和修改使用:2. "^\d+$" //非负整数(正整数 + 0)3. "^[0-9 ...
- JS常用各种正则表达式
1.非负整数 /^\d+$/ 2.正整数 /^[0-9]*[1-9][0-9]*$/ 3.非正整数 /^((-\d+)|(0+))$/ 4.负整数 ...
- js常用的正则表达式
一.校验数字的表达式 数字:^[0-9]*$ n位的数字:^\d{n}$ 至少n位的数字:^\d{n,}$ m-n位的数字:^\d{m,n}$ 零和非零开头的数字:^(0|[1-9][0-9]*)$ ...
- JS常用各种正则表达式(汇总)
匹配URL 这个url的正则表达式判断的JavaScript!比较全面的.它验证的情况包括IP,域名(domain),ftp,二级域名,域名中的文件,域名加上端口!用户名等等信息, function ...
- JS常用的正则表达式包
结构: Code: /* 用途:检查输入的Email信箱格式是否正确 输入:strEmail:字符串 返回:如果通过验证返回true,否则返回false */ function checkEmail( ...
- JS常用正则表达式备忘录
摘要: 玩转正则表达式. 原文:JS常用正则表达式备忘录 作者:前端小智 Fundebug经授权转载,版权归原作者所有. 正则表达式或"regex"用于匹配字符串的各个部分 下面是 ...
- js常用正则表达式,滚蛋吧!你们测试组bug,让你挑
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...
- js中常用的正则表达式
我一般对正则的使用方式如下,该方法会返回一个boolean值,然后对这个返回值来进行判断 // 判断是否是整数 function isInt(num) { var reg = new RegExp(& ...
- js中的正则表达式
一.正则中的汉字 常见的:/[^\x00-\x7F]+?/ /^[\u2E80-\u9FFF]+$/ 过滤汉字即是:string.replace(/^[\u2E80-\u9FFF]+$/g, &quo ...
随机推荐
- Error on line -1 of document : Premature end of file. Nested exception: Premature end of file.
启动tomcat, 出现, ( 之前都是好好的... ) [lk ] ERROR [08-12 15:10:02] [main] org.springframework.web.context.Con ...
- Android 浏览器 —— 使用 WebView 实现文件下载
对当前的WebView设置下载监听 mCurrentWebView.setDownloadListener(new DownloadListener() { @Override public void ...
- es6 新特性2
es6其他几个非常有用的新特性. import export 这两个家伙对应的就是es6自己的module功能. 我们之前写的Javascript一直都没有模块化的体系,无法将一个庞大的js工程拆分成 ...
- 解析大型.NET ERP系统 灵活复杂的界面控件Infragistics WinForms
Infragistics 是.NET平台优秀的控件供应商,囊括了WinForms,ASP.NET,Silverlight,WPF,Windows Phone等所有关于微软.NET技术的界面控件.借助于 ...
- 在 CSS 预编译器之后:PostCSS
提到css预编译器(css preprocessor),你可能想到Sass.Less以及Stylus.而本文要介绍的PostCSS,正是一个这样的工具:css预编译器可以做到的事,它同样可以做到. “ ...
- 3. 解析 struts.xml 文件
1. struts.xml 文件基本配置: 主要放在资源路径下,配置 sturts2相关的 Action , 拦截器等配置 <struts> <!-- 设置常量 --> < ...
- 如何修复Windows 10 Enterprise 在9月更新后图片全部由绘图板打开的情况
在进行了本月更新日的洗礼之后,企业版的Windows 10 突然发现无法好好的进行图片查看. 因为更新之前,各种图片都是使用“照片程序”打开的(这个是photos app),然后更新之后,这个app就 ...
- jvm系列(五):tomcat性能调优和性能监控(visualvm)
tomcat服务器优化 1.JDK内存优化 根据服务器物理内容情况配置相关参数优化tomcat性能.当应用程序需要的内存超出堆的最大值时虚拟机就会提示内存溢出,并且导致应用服务崩溃.因此一般建议堆的最 ...
- 【分布式】Zookeeper的服务器角色
一.前言 前一篇已经详细的讲解了Zookeeper的Leader选举过程,下面接着学习Zookeeper中服务器的各个角色及其细节. 二.服务器角色 2.1 Leader Leader服务器是Zook ...
- es6学习笔记一数组(上)
最近公司没什么事情,我们老大让我看看es6,小颖就练习了下数组的各个方法,今天先给大家分享一部分.嘻嘻,希望对大家有所帮助. every方法: 概述: every() 方法测试数组的所有元素是否 ...