常用正则表达式收集

用户名正则

JavaScript 代码:

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

密码强度正则

JavaScript 代码:

  1. //密码强度正则,最少6位,包括至少1个大写字母,1个小写字母,1个数字,1个特殊字符
  2. var pPattern = /^.*(?=.{6,})(?=.*\d)(?=.*[A-Z])(?=.*[a-z])(?=.*[!@#$%^&*? ]).*$/;
  3. //输出 true
  4. console.log("=="+pPattern.test("caibaojian#"));
  5.  
  6. //密码强度正则,6-18英文或数字密码
          var pPattern = /^[a-zA-Z0-9]{6,18}$/;
          console.log(pPattern.test("123456"));//true
    

整数正则

JavaScript 代码:

  1. //正整数正则
  2. var posPattern = /^\d+$/;
  3. //负整数正则
  4. var negPattern = /^-\d+$/;
  5. //整数正则
  6. var intPattern = /^-?\d+$/;
  7. //输出 true
  8. console.log(posPattern.test("42"));
  9. //输出 true
  10. console.log(negPattern.test("-42"));
  11. //输出 true
  12. console.log(intPattern.test("-42"));

数字正则

可以是整数也可以是浮点数

JavaScript 代码:

  1. //正数正则
  2. var posPattern = /^\d*\.?\d+$/;
  3. //负数正则
  4. var negPattern = /^-\d*\.?\d+$/;
  5. //数字正则
  6. var numPattern = /^-?\d*\.?\d+$/;
  7. console.log(posPattern.test("42.2"));
  8. console.log(negPattern.test("-42.2"));
  9. console.log(numPattern.test("-42.2"));

Email正则

JavaScript 代码:

  1. //Email正则
  2. var ePattern = /^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/;
  3. //输出 true
  4. console.log(ePattern.test("99154507@qq.com"));

手机号码正则

JavaScript 代码:

  1. //手机号正则
  2. var mPattern = /^1[34578]\d{9}$/; //http://caibaojian.com/regexp-example.html
  3. //输出 true
  4. console.log(mPattern.test("15507621888"));

身份证号正则

JavaScript 代码:

  1. //身份证号(18位)正则
  2. var cP = /^[1-9]\d{5}(18|19|([23]\d))\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/;
  3. //输出 true
  4. console.log(cP.test("11010519880605371X"));

注:身份号码验证建议查看《关于身份证号码验证的几个实用函数

URL正则

JavaScript 代码:

  1. //URL正则
  2. var urlP= /^((https?|ftp|file):\/\/)?([\da-z\.-]+)\.([a-z\.]{2,6})([\/\w \.-]*)*\/?$/;
  3. //输出 true
  4. console.log(urlP.test("http://caibaojian.com"));

IPv4地址正则

JavaScript 代码:

  1. //ipv4地址正则
  2. var ipP = /^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/;
  3. //输出 true
  4. console.log(ipP.test("115.28.47.26"));

十六进制颜色正则

JavaScript 代码:

  1. //RGB Hex颜色正则
  2. var cPattern = /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/;
  3. //输出 true
  4. console.log(cPattern.test("#b8b8b8"));

日期正则

JavaScript 代码:

  1. //日期正则,简单判定,未做月份及日期的判定
  2. var dP1 = /^\d{4}(\-)\d{1,2}\1\d{1,2}$/;
  3. //输出 true
  4. console.log(dP1.test("2017-05-11"));
  5. //输出 true
  6. console.log(dP1.test("2017-15-11"));
  7. //日期正则,复杂判定
  8. var dP2 = /^(?:(?!0000)[0-9]{4}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-8])|(?:0[13-9]|1[0-2])-(?:29|30)|(?:0[13578]|1[02])-31)|(?:[0-9]{2}(?:0[48]|[2468][048]|[13579][26])|(?:0[48]|[2468][048]|[13579][26])00)-02-29)$/;
  9. //输出 true
  10. console.log(dP2.test("2017-02-11"));
  11. //输出 false
  12. console.log(dP2.test("2017-15-11"));
  13. //输出 false
  14. console.log(dP2.test("2017-02-29"));

QQ号码正则

JavaScript 代码:

  1. //QQ号正则,5至11位
  2. var qqPattern = /^[1-9][0-9]{4,10}$/;
  3. //输出 true
  4. console.log(qqPattern.test("65974040"));

微信号正则

JavaScript 代码:

  1. //微信号正则,6至20位,以字母开头,字母,数字,减号,下划线
  2. var wxPattern = /^[a-zA-Z]([-_a-zA-Z0-9]{5,19})+$/;
  3. //输出 true
  4. console.log(wxPattern.test("caibaojian_com"));

车牌号正则

JavaScript 代码:

  1. //车牌号正则
  2. var cPattern = /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领A-Z]{1}[A-Z]{1}[A-Z0-9]{4}[A-Z0-9挂学警港澳]{1}$/;
  3. //输出 true
  4. console.log(cPattern.test("浙AKP053"));

包含中文正则

JavaScript 代码:

  1. //包含中文正则
  2. var cnPattern = /[\u4E00-\u9FA5]/;
  3. //输出 true
  4. console.log(cnPattern.test("愚人码头"));

图片正则

function checkSuffix(str)
{
  var strRegex = "(.jpg|.png|.gif|.ps|.jpeg)$"; //用于验证图片扩展名的正则表达式
  var re=new RegExp(strRegex);
  if (re.test(str.toLowerCase())){
    return true;
  } else{
    alert("文件名不合法"); 
    return false;
  }
}

校验数字的表达式

  • 数字:^[0-9]*$
  • n位的数字:^\d{n}$
  • 至少n位的数字:^\d{n,}$
  • m-n位的数字:^\d{m,n}$
  • 零和非零开头的数字:^(0|[1-9][0-9]*)$
  • 非零开头的最多带两位小数的数字:^([1-9][0-9]*)+(.[0-9]{1,2})?$
  • 带1-2位小数的正数或负数:^(\-)?\d+(\.\d{1,2})?$
  • 正数、负数、和小数:^(\-|\+)?\d+(\.\d+)?$
  • 有两位小数的正实数:^[0-9]+(.[0-9]{2})?$
  • 有1~3位小数的正实数:^[0-9]+(.[0-9]{1,3})?$
  • 非零的正整数:^[1-9]\d*$ 或 ^([1-9][0-9]*){1,3}$ 或 ^\+?[1-9][0-9]*$
  • 非零的负整数:^\-[1-9][]0-9"*$ 或 ^-[1-9]\d*$
  • 非负整数:^\d+$ 或 ^[1-9]\d*|0$
  • 非正整数:^-[1-9]\d*|0$ 或 ^((-\d+)|(0+))$
  • 非负浮点数:^\d+(\.\d+)?$ 或 ^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$
  • 非正浮点数:^((-\d+(\.\d+)?)|(0+(\.0+)?))$ 或 ^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$
  • 正浮点数:^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$ 或 ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$
  • 负浮点数:^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$ 或 ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$
  • 浮点数:^(-?\d+)(\.\d+)?$ 或 ^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$

校验字符的表达式

  • 汉字:^[\u4e00-\u9fa5]{0,}$
  • 英文和数字:^[A-Za-z0-9]+$ 或 ^[A-Za-z0-9]{4,40}$
  • 长度为3-20的所有字符:^.{3,20}$
  • 由26个英文字母组成的字符串:^[A-Za-z]+$
  • 由26个大写英文字母组成的字符串:^[A-Z]+$
  • 由26个小写英文字母组成的字符串:^[a-z]+$
  • 由数字和26个英文字母组成的字符串:^[A-Za-z0-9]+$
  • 由数字、26个英文字母或者下划线组成的字符串:^\w+$ 或 ^\w{3,20}$
  • 中文、英文、数字包括下划线:^[\u4E00-\u9FA5A-Za-z0-9_]+$
  • 可以输入含有^%&’,;=?$\”等字符:[^%&',;=?$\x22]+
  • 禁止输入含有~的字符:[^~\x22]+

特殊需求表达式

  • Email地址:^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$
  • 域名:[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.?
  • InternetURL:[a-zA-z]+://[^\s]* 或 ^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$
  • 手机号码:^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$
  • 电话号码(“XXX-XXXXXXX”、”XXXX-XXXXXXXX”、”XXX-XXXXXXX”、”XXX-XXXXXXXX”、”XXXXXXX”和”XXXXXXXX):^(\(\d{3,4}-)|\d{3.4}-)?\d{7,8}$
  • 国内电话号码(0511-4405222、021-87888822):\d{3}-\d{8}|\d{4}-\d{7}
  • 身份证号(15位、18位数字):^\d{15}|\d{18}$
  • 短身份证号码(数字、字母x结尾):^([0-9]){7,18}(x|X)?$ 或 ^\d{8,18}|[0-9x]{8,18}|[0-9X]{8,18}?$
  • 帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
  • 密码(以字母开头,长度在6~18之间,只能包含字母、数字和下划线):^[a-zA-Z]\w{5,17}$
  • 强密码(必须包含大小写字母和数字的组合,不能使用特殊字符,长度在8-10之间):^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$
  • 日期格式:^\d{4}-\d{1,2}-\d{1,2}
  • 一年的12个月(01~09和1~12):^(0?[1-9]|1[0-2])$
  • 一个月的31天(01~09和1~31):^((0?[1-9])|((1|2)[0-9])|30|31)$
  • xml文件:^([a-zA-Z]+-?)+[a-zA-Z0-9]+\\.[x|X][m|M][l|L]$
  • 中文字符的正则表达式:[\u4e00-\u9fa5]
  • 双字节字符:[^\x00-\xff] (包括汉字在内,可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1))
  • 空白行的正则表达式:\n\s*\r (可以用来删除空白行)
  • HTML标记的正则表达式:< (\S*?)[^>]*>.*?|< .*? /> (网上流传的版本太糟糕,上面这个也仅仅能部分,对于复杂的嵌套标记依旧无能为力)
  • 首尾空白字符的正则表达式:^\s*|\s*$或(^\s*)|(\s*$) (可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式)
  • 腾讯QQ号:[1-9][0-9]{4,} (腾讯QQ号从10000开始)
  • 中国邮政编码:[1-9]\d{5}(?!\d) (中国邮政编码为6位数字)
  • IP地址:\d+\.\d+\.\d+\.\d+ (提取IP地址时有用)
  • IP地址:((?:(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d))
  • 港澳居民来往内地通行证号码验证正则: /^([A-Z]\d{6,10}(\(\w{1}\))?)$/
  • 护照验证正则: /^(P\d{7}|G\d{7,8}|TH\d{7,8}|S\d{7,8}|A\d{7,8}|L\d{7,8}|\d{9}|D\d+|1[4,5]\d{7})$/注:身份号码验证建议查看《关于身份证号码验证的几个实用函数

钱的输入格式:

  • 有四种钱的表示形式我们可以接受:”10000.00″ 和 “10,000.00”, 和没有 “分” 的 “10000” 和 “10,000”:^[1-9][0-9]*$
  • 这表示任意一个不以0开头的数字,但是,这也意味着一个字符”0″不通过,所以我们采用下面的形式:^(0|[1-9][0-9]*)$
  • 一个0或者一个不以0开头的数字.我们还可以允许开头有一个负号:^(0|-?[1-9][0-9]*)$
  • 这表示一个0或者一个可能为负的开头不为0的数字.让用户以0开头好了.把负号的也去掉,因为钱总不能是负的吧.下面我们要加的是说明可能的小数部分:^[0-9]+(.[0-9]+)?$
  • 必须说明的是,小数点后面至少应该有1位数,所以”10.”是不通过的,但是 “10” 和 “10.2” 是通过的:^[0-9]+(.[0-9]{2})?$
  • 这样我们规定小数点后面必须有两位,如果你认为太苛刻了,可以这样:^[0-9]+(.[0-9]{1,2})?$
  • 这样就允许用户只写一位小数.下面我们该考虑数字中的逗号了,我们可以这样:^[0-9]{1,3}(,[0-9]{3})*(.[0-9]{1,2})?$
  • 1到3个数字,后面跟着任意个 逗号+3个数字,逗号成为可选,而不是必须:^([0-9]+|[0-9]{1,3}(,[0-9]{3})*)(.[0-9]{1,2})?$

备注:这就是最终结果了,别忘了”+”可以用”*”替代如果你觉得空字符串也可以接受的话(奇怪,为什么?)最后,别忘了在用函数时去掉去掉那个反斜杠,一般的错误都在这里

更多收集的正则

常见的 正则表达式 校验:QQ号、手机号、Email、是否是数字、去掉前后空格、是否存在中文、邮编、身份证、URL、日期格式、IP

JavaScript 代码:

  1. var myRegExp = {
  2. // 检查字符串是否为合法QQ号码
  3. isQQ: function(str) {
  4. // 1 首位不能是0 ^[1-9]
  5. // 2 必须是 [5, 11] 位的数字 \d{4, 9}
  6. var reg = /^[1-9][0-9]{4,9}$/gim;
  7. if (reg.test(str)) {
  8. console.log('QQ号码格式输入正确');
  9. return true;
  10. } else {
  11. console.log('请输入正确格式的QQ号码');
  12. return false;
  13. }
  14. },
  15. // 检查字符串是否为合法手机号码
  16. isPhone: function(str) {
  17. var reg = /^(0|86|17951)?(13[0-9]|15[012356789]|18[0-9]|14[57]|17[678])[0-9]{8}$/;
  18. if (reg.test(str)) {
  19. console.log('手机号码格式输入正确');
  20. return true;
  21. } else {
  22. console.log('请输入正确格式的手机号码');
  23. return false;
  24. }
  25. },
  26. // 检查字符串是否为合法Email地址
  27. isEmail: function(str) {
  28. var reg = /^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/;
  29. // var reg = /\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/;
  30. if (reg.test(str)) {
  31. console.log('Email格式输入正确');
  32. return true;
  33. } else {
  34. console.log('请输入正确格式的Email');
  35. return false;
  36. }
  37. },
  38. // 检查字符串是否是数字
  39. isNumber: function(str) {
  40. var reg = /^\d+$/;
  41. if (reg.test(str)) {
  42. console.log(str + '是数字');
  43. return true;
  44. } else {
  45. console.log(str + '不是数字');
  46. return false;
  47. }
  48. },
  49. // 去掉前后空格
  50. trim: function(str) {
  51. var reg = /^\s+|\s+$/g;
  52. return str.replace(reg, '');
  53. },
  54. // 检查字符串是否存在中文
  55. isChinese: function(str) {
  56. var reg = /[\u4e00-\u9fa5]/gm;
  57. if (reg.test(str)) {
  58. console.log(str + ' 中存在中文');
  59. return true;
  60. } else {
  61. console.log(str + ' 中不存在中文');
  62. return false;
  63. }
  64. },
  65. // 检查字符串是否为合法邮政编码
  66. isPostcode: function(str) {
  67. // 起始数字不能为0,然后是5个数字 [1-9]\d{5}
  68. var reg = /^[1-9]\d{5}$/g;
  69. // var reg = /^[1-9]\d{5}(?!\d)$/;
  70. if (reg.test(str)) {
  71. console.log(str + ' 是合法的邮编格式');
  72. return true;
  73. } else {
  74. console.log(str + ' 是不合法的邮编格式');
  75. return false;
  76. }
  77. },
  78. // 检查字符串是否为合法身份证号码
  79. isIDcard: function(str) {
  80. var reg = /^(^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$)|(^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])((\d{4})|\d{3}[Xx])$)$/;
  81. if (reg.test(str)) {
  82. console.log(str + ' 是合法的身份证号码');
  83. return true;
  84. } else {
  85. console.log(str + ' 是不合法的身份证号码');
  86. return false;
  87. }
  88. },
  89. // 检查字符串是否为合法URL
  90. isURL: function(str) {
  91. var reg = /^https?:\/\/(([a-zA-Z0-9_-])+(\.)?)*(:\d+)?(\/((\.)?(\?)?=?&?[a-zA-Z0-9_-](\?)?)*)*$/i;
  92. if (reg.test(str)) {
  93. console.log(str + ' 是合法的URL');
  94. return true;
  95. } else {
  96. console.log(str + ' 是不合法的URL');
  97. return false;
  98. }
  99. },
  100. // 检查字符串是否为合法日期格式 yyyy-mm-dd
  101. isDate: function(str) {
  102. var reg = /^[1-2][0-9][0-9][0-9]-[0-1]{0,1}[0-9]-[0-3]{0,1}[0-9]$/;
  103. if (reg.test(str)) {
  104. console.log(str + ' 是合法的日期格式');
  105. return true;
  106. } else {
  107. console.log(str + ' 是不合法的日期格式,yyyy-mm-dd');
  108. return false;
  109. }
  110. },
  111. // 检查字符串是否为合法IP地址
  112. isIP: function(str) {
  113. // 1.1.1.1 四段 [0 , 255]
  114. // 第一段不能为0
  115. // 每个段不能以0开头
  116. //
  117. // 本机IP: 58.50.120.18 湖北省荆州市 电信
  118. var reg = /^([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])(\.([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])){3}$/gi;
  119. if (reg.test(str)) {
  120. console.log(str + ' 是合法的IP地址');
  121. return true;
  122. } else {
  123. console.log(str + ' 是不合法的IP地址');
  124. return false;
  125. }
  126. }
  127. }
  128. // 测试
  129. // console.log(myRegExp.isQQ('80583600'));
  130. // console.log(myRegExp.isPhone('17607160722'));
  131. // console.log(myRegExp.isEmail('80583600@qq.com'));
  132. // console.log(myRegExp.isNumber('100a'));
  133. // console.log(myRegExp.trim(' 100 '));
  134. // console.log(myRegExp.isChinese('baixiaoming'));
  135. // console.log(myRegExp.isChinese('小明'));
  136. // console.log(myRegExp.isPostcode('412345'));
  137. // console.log(myRegExp.isIDcard('42091119940927001X'));
  138. // console.log(myRegExp.isURL('https://www.baidu.com/'));
  139. // console.log(myRegExp.isDate('2017-4-4'));
  140. // console.log(myRegExp.isIP('1.0.0.0'));
  141. 原文链接:点击打开链接
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值