JS常用正则表达式总结【经典】


Posted in Javascript onMay 12, 2017

本文实例讲述了JS常用正则表达式。分享给大家供大家参考,具体如下:

在项目中个人写的一个常用验证的正则表达式:(仅供参考)

//定义两个全局变量
var reg;
var errorInfo;
//输入的数字类型必须是int型,正负整数都可以
function validate_integer(text,value){
reg=/^[-\+]?\d+$/;
errorInfo=text+" "+value+" 只能是整数,请核实重新输入!";
verifyByReg(value,reg,errorInfo);
}
//输入的数字类型必须是double型,保留的小数位数只能是2位,可以为正负
function validate_double(text,value){
reg=/^[-\+]?([1-9](\d+)?|0)(\.\d{2})$/;
errorInfo=text+" "+value+" 只能保留2为小数,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//输入的必须是全是数字类型型,不能出现其他字符
function validate_number(text,value){
reg=/^\d+$/;
errorInfo=text+" "+value+" 只能是数字,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证输入n位的数值类型
function validate_number_n(text,value,n){
reg=eval("/^\\d{"+n+"}$/");
errorInfo=text+" "+value+" 只能是"+n+"位数字,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证有两位小数的正实数
function validate_decimal_two(text,value){
reg=/^([1-9](\d+)?|0)(.[0-9]{2})?$/;
errorInfo=text+" "+value+" 只能是保留2位小数的正数,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证非零的正整数
function validate_number_positive(text,value){
reg=/^\+?[1-9][0-9]*$/;
errorInfo=text+" "+value+" 只能是非0的正整数,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证非零的负整数
function validate_number_negative(text,value){
reg=/^[-][1-9][0-9]*$/;
errorInfo=text+" "+value+" 只能是非0的负整数,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证非负整数,可以为0
function validate_positive_haszero(text,value){
reg=/^[1-9](\d+)?|0$/;
errorInfo=text+" "+value+" 只能是是0或正整数,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证非正整数,可以为0
function validate_negative_haszero(text,value){
reg=/^\-[1-9](\d+)?|0$/;
errorInfo=text+" "+value+" 只能是是0或负整数,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证非负浮点数(正浮点数 + 0)
function validate_float_notnegative(text,value){
reg=/^([1-9](\d+)?|0)(\.\d+)|0$/;
errorInfo=text+" "+value+" 只能是是0或正浮点数,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证正浮点数
function validate_float_positive(text,value){
reg=/^([1-9](\d+)?|0)(\.\d+)$/;
errorInfo=text+" "+value+" 只能是正浮点数,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//非正浮点数(负浮点数 + 0)
function validate_float_notpositive(text,value){
reg=/^\-([1-9](\d+)?|0)(\.\d+)|0$/;
errorInfo=text+" "+value+" 只能是是0或者负浮点数,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证负浮点数
function validate_float_negative(text,value){
reg=/^\-([1-9](\d+)?|0)(\.\d+)$/;
errorInfo=text+" "+value+" 只能是负浮点数,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证正浮点数多少位小数
function validate_float_posbit(text,value,n){
reg=eval("/^(\\d+)(\\.\\d{"+n+"})$/");
errorInfo=text+" "+value+" 只能是"+n+"位正浮点数,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证负浮点数多少位小数
function validate_float_negbit(text,value,n){
reg=eval("/^(-?\\d+)(\\.\\d{"+n+"})$/");
errorInfo=text+" "+value+" 只能是"+n+"位负浮点数,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//校验文本是否为空
function checknull(text,value){
if(value=="" || typeof(value)=='undefined'){
errorInfo=text+" "+value+" 不能为空,请重新输入!";
returnInfo(errorInfo);
}
}
//验证由26个英文字母组成的字符串
function validate_string_letter(text,value){
reg=/^[A-Za-z]+$/;
errorInfo=text+" "+value+" 只能是26位不区分大小写的英文字母组成,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证由26个英文字母的大写组成的字符串
function validate_string_bigletter(text,value){
reg=/^[A-Z]+$/;
errorInfo=text+" "+value+" 只能是26位大写的英文字母组成,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证由26个英文字母的小写组成的字符串
function validate_string_smallletter(text,value){
reg=/^[a-z]+$/;
errorInfo=text+" "+value+" 只能是26位小写的英文字母组成,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证由数字和26个英文字母组成的字符串
function validate_string_number(text,value){
reg=/^[A-Za-z0-9]+$/;
errorInfo=text+" "+value+" 只能是数字和26个英文字母组成,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证由数字、26个英文字母或者下划线组成的字符串
function validate_string_numberandunderline(text,value){
reg=/^\w+$/;
errorInfo=text+" "+value+" 只能是数字、26个英文字母或者下划线组成,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证邮箱
function validate_email(value){
reg=/^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/;
errorInfo='邮箱 '+value+" 无效,请重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证时如果选择默认调用此方法 金额类型,可以是正整数或保留4位有效数字的正整数
/**有问题
function validate_money_default(text,value){
var reg=/^\d+(\.\d{4})?$/;
var errorInfo=text+" "+value+" 只能是正整数或保留4位有效数字,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
**/
//验证输入的只能是中文
function validate_chinese(text,value){
reg=/^[\u4e00-\u9fa5]+$/;
errorInfo=text+" "+value+" 只能是中文字符,请重新输入";
verifyByReg(value,reg,errorInfo);
}
//验证输入的只能是n位的中文
function validate_bitchinese(text,value,bit){
reg=eval("/^[\\u4e00-\\u9fa5]{"+bit+"}$/");alert(reg);
errorInfo=text+" "+value+" 只能是"+bit+"位中文字符,请重新输入";
verifyByReg(value,reg,errorInfo);
}
//跟最大的值比较,此方法是看数字是否超出系统的上限
function thanMax(text,number,max){
if(number>max){
errorInfo=text+" "+number+" 不能大于"+max+",请重新输入";
returnInfo(errorInfo);
}
}
//跟最小的值比较,此方法是看数字是否低于系统的下限
function thinMin(text,number,min){
if(number<min){
errorInfo=text +" "+number+" 不能小于"+min+",请重新输入";
returnInfo(errorInfo);
}
}
//输入文本的字符串是否在系统的指定长度内
function isLimit(text,value,length){
var arr=value.split("");
if(arr.length>length){
errorInfo=text +" "+value+" 字符过长,请输入最多"+length+"位字符";
returnInfo(errorInfo);
}
}
//邮政编码的验证
function validate_zipcode(value){
reg=/[1-9]\d{5}(?!\d)/;
errorInfo='邮政编码 '+value+" 有误,请核实重新输入";
verifyByReg(value,reg,errorInfo);
}
//对数值类型的数据进行简单的验证和转换,因为在设置的时候没有传入这个参数的话就会出现js代码错误,所以应该对数值型的数据进行转换
//非空字符的判定
function getZeroByNull(text,value){
errorInfo=text+" "+value+" 不能为空,请核实重新输入";
if(value==null||value==''||value=='undefined'){
returnInfo(errorInfo);
}
}
//身份证验证,分为了两种,15位和18位
function validate_IdCard(value){
var size=value.split("");
if(size.length==15){
reg=/^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$/;//15位身份证验证
errorInfo='位身份证号码 '+value+" 有误,请核实重新输入";
}else if(size.length==18){
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|x)$/;//18位身份证验证
errorInfo='位身份证号码 '+value+" 有误,请核实重新输入";
}else{
errorInfo="请输入合法的身份证号码!";
returnInfo(errorInfo);
}
verifyByReg(value,reg,errorInfo);
}
//每个验证都需要调用此方法
function verifyByReg(value,reg,errorInfo){
if(value!=''&®!=''){
var regExp = new RegExp(reg);
if(!regExp.test(value)){
alert(errorInfo);
throw errorInfo;
}
}
}
//不进过正则表达式验证,只需要返回信息,适合内部调用此方法
function returnInfo(message){
alert(message);
throw message;
}
//许可证号 生产企业的格式:QS 1234 2346 3456 其中空格可有可无
///经营企业许可证的格式为: 湘010249 但是中国的省会简称可能会有三个字的,所以中文可以定义为1-3个
function validate_license(value,type){
if(type==1){
reg=/^[a-zA-Z]{2}[ ]?(\d{4}[ ]?\d{4}[ ]?\d{4})$/;//生产企业许可证号
errorInfo="生产许可证号 "+value+" 有误,请核实重新输入!";
}else if(type==2){
reg=/^[\u4e00-\u9fa5]{1,3}\d{6}$/;
errorInfo="经营许可证号 "+value+" 有误,请核实重新输入!";
}
verifyByReg(value,reg,errorInfo);
}
//传真 可以匹配的字符串如:+123 -999 999 ; +123-999 999 ;123 999 999 ;+123 999999等
function validate_fax(value){
reg=/^([+]{0,1})?\d{1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/;
errorInfo="传真 "+value+" 有误,请重新输入!";
verifyByReg(value,reg,errorInfo);
}
//电话号码可以输入:电话或者手机 其中手机号码可以是(+86)、(86)+号码,也可以是号码 电话的号码可以是区号+号码 区号-号码 号码
function validate_tel(value){
reg=/(^(0\d{2,3}([-|+])?)?\d{7}$)|(^(\d{3,4}([-|+])?)?\d{7,8}$)|(^([+]?(86)?[+]?)1[3-9]\d{9}$)/;
errorInfo='电话号码 '+value+" 有误,请核实重新输入!";
verifyByReg(value,reg,errorInfo);
}
//日:大于0小于等于31的正整数
function validate_day(value){
reg=/(^[0]?[1-9]$)|(^[1-2]\d$)|(^[3][0-1]$)/;
errorInfo='日期 '+value+" 有误,请核实重新输入!";
verifyByReg(value,reg,errorInfo);
}
//月:合法月份
function validate_month(value){
reg=/(^[0]?[1-9]$)|(^[1][0-2]$)/;
errorInfo='月份 '+value+" 有误,请核实重新输入!";
verifyByReg(value,reg,errorInfo);
}
//年:合法年份 在这里合法的年份为公元1000年至公元2999年
function validate_year(value){
reg=/^[1-2]\d{3}$/;
errorInfo='年份 '+value+" 有误,请核实重新输入!";
verifyByReg(value,reg,errorInfo);
}
//百分比:合法百分比(0-100之前的数字)
function validate_percentage(text,value){
reg=/(^[1-9](\d)?(\.\d+)?$)|(^0(\.\d+)?$)|(^100$)/;
errorInfo=text +" "+value+" 有误,请输入0到100的数字!";
verifyByReg(value,reg,errorInfo);
}
//系数:小于等于1的正数 在这里系数的小数点后面也是2位
function validate_modulus(text,value){
reg=/^[0](\.\d{2})$|^[1](\.[0]{2})?$/;
errorInfo=text+" "+value+" 有误,请输入小于0到1的数字!";
verifyByReg(value,reg,errorInfo);
}
//验证非负的正数,包含了正整数和正浮点数
function validate_posnumhaszero(text,value){
checknull(text,value);
reg=/^[1-9](\d+)?(\.\d+)?$|^0(\.\d+)?$/;
errorInfo=text+" "+value+" 有误,请输入大于或等于0 的数字!";
verifyByReg(value,reg,errorInfo);
}
//验证非正的负数,包含了负整数和负浮点数
function validate_negnumhaszero(text,value){
checknull(text,value);
reg=/^[-][1-9](\d+)?(\.\d+)?$|^[-]0(\.\d+)?$/;
errorInfo=text+" "+value+" 有误,请输入小于或等于0 的数字!";
verifyByReg(value,reg,errorInfo);
}
//验证正数,包含了正整数和正浮点数
function validate_posnum(text,value){
checknull(text,value);
reg=/^[1-9](\d+)?(\.\d+)?$|^0(\.\d+)$/;
errorInfo=text+" "+value+" 有误,请输入大于0 的数字!";
verifyByReg(value,reg,errorInfo);
}
//验证负数,包含了负整数和负浮点数
function validate_negnum(text,value){
checknull(text,value);
reg=/^[-][1-9](\d+)?(\.\d+)?$|^[-]0(\.\d+)$/;
errorInfo=text+" "+value+" 有误,请输入小于0 的数字!";
verifyByReg(value,reg,errorInfo);
}
//验证数,包括所有的数值,正数、负数、正浮点数、负浮点数
function validate_allnum(text,value){
checknull(text,value);
reg=/^[-|+]?[1-9](\d+)?(\.\d+)?$|^[-|+]?0(\.\d+)?$/;
errorInfo=text+" "+value+" 有误,请输入数字!";
verifyByReg(value,reg,errorInfo);
}
Javascript 相关文章推荐
JavaScript 轻松搞定快捷留言功能 只需一行代码
Apr 01 Javascript
jQuery帮助之筛选查找 children([expr])
Jan 31 Javascript
php图像生成函数之间的区别分析
Dec 06 Javascript
IE6已终止操作问题的2种情况及解决
Apr 23 Javascript
编写高效jQuery代码的4个原则和5个技巧
Apr 24 Javascript
jQuery Ajax()方法使用指南
Nov 19 Javascript
js代码实现随机颜色的小方块
Jul 30 Javascript
JQuery解析XML的方法小结
Apr 02 Javascript
JS区分浏览器页面是刷新还是关闭
Apr 17 Javascript
JavaScript重复元素处理方法分析【统计个数、计算、去重复等】
Dec 14 Javascript
小程序从手动埋点到自动埋点的实现方法
Jan 24 Javascript
使用koa2创建web项目的方法步骤
Mar 12 Javascript
vue.js的安装方法
May 12 #Javascript
JS匹配日期和时间的正则表达式示例
May 12 #Javascript
js如何获取网页所有图片
May 12 #Javascript
require.js与bootstrap结合实现简单的页面登录和页面跳转功能
May 12 #Javascript
jQuery手风琴的简单制作
May 12 #jQuery
jQuery.ajax向后台传递数组问题的解决方法
May 12 #jQuery
Centos6.8下Node.js安装教程
May 12 #Javascript
You might like
短波的认识
2021/03/01 无线电
PHP中常用数组处理方法实例分析
2008/08/30 PHP
PHP通过内置函数memory_get_usage()获取内存使用情况
2014/11/20 PHP
PHP请求Socket接口测试实例
2016/08/12 PHP
基于jquery实现的可以编辑选择的下拉框的代码
2010/11/19 Javascript
jQuery 对Select的操作备忘记录
2011/07/04 Javascript
js传参数受特殊字符影响错误的解决方法
2013/10/21 Javascript
页面图片浮动左右滑动效果的简单实现案例
2014/02/10 Javascript
javascript自定义in_array()函数实现方法
2015/08/03 Javascript
easyui Draggable组件实现拖动效果
2015/08/19 Javascript
简单的js计算器实现
2016/10/26 Javascript
javaScript中定义类或对象的五种方式总结
2016/12/04 Javascript
JavaScript利用闭包实现模块化
2017/01/13 Javascript
bootstrap table表格插件使用详解
2017/05/08 Javascript
详解用vue.js和laravel实现微信授权登陆
2017/06/23 Javascript
vue router学习之动态路由和嵌套路由详解
2017/09/21 Javascript
基于Bootstrap实现城市三级联动
2017/11/23 Javascript
JS简单实现查看文档创建日期、修改日期和文档大小的方法示例
2018/04/08 Javascript
js事件on动态绑定数据,绑定多个事件的方法
2018/09/15 Javascript
vue-devtools的安装和使用步骤详解
2019/10/17 Javascript
python使用urllib模块开发的多线程豆瓣小站mp3下载器
2014/01/16 Python
python中xrange用法分析
2015/04/15 Python
Python模糊查询本地文件夹去除文件后缀的实例(7行代码)
2017/11/09 Python
解决Python plt.savefig 保存图片时一片空白的问题
2019/01/10 Python
python输入错误后删除的方法
2019/10/12 Python
PyCharm永久激活方式(推荐)
2020/09/22 Python
浅谈django channels 路由误导
2020/05/28 Python
Python常用扩展插件使用教程解析
2020/11/02 Python
美国知名户外用品畅销中心:Sierra Trading Post
2016/07/19 全球购物
adidas菲律宾官网:adidas PH
2020/02/07 全球购物
财务工作者先进事迹材料
2014/01/17 职场文书
优秀食品类广告词
2014/03/19 职场文书
负责人任命书范本
2014/06/04 职场文书
中学生旷课检讨书模板
2014/10/08 职场文书
如何书写民事调解协议书?
2019/06/25 职场文书
用python基于appium模块开发一个自动收取能量的小助手
2021/09/25 Python