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

本文提供了一系列JavaScript正则表达式,用于验证用户名、密码强度、整数、数字、电子邮件地址、手机号码、身份证号、URL地址、IPv4地址、十六进制颜色、日期、QQ号码、微信号、车牌号、中文等常见输入格式,是前端表单验证的得力助手。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

15个常用的javaScript正则表达式,其中包括用户名、密码强度、整数、数字、电子邮件地址(Email)、手机号码、身份证号、URL地址、 IPv4地址、 十六进制颜色、 日期、 QQ号码、 微信号、车牌号、中文正则。表单验证处理必备。

1. 用户名正则

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

2. 密码强度正则

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

//最少8-16位,由大小写字母、数字、特殊字符中至少两个以上组成
var pPattern = /^.*(?=.{8,16})((?=.*\d)(?=.*[A-Z]))|((?=.*\d)(?=.*[a-z]))|((?=.*\d)(?=.*[!@#$%^&*? ]))|((?=.*[A-Z])(?=.*[a-z]))|((?=.*[A-Z])(?=.*[!@#$%^&*? ]))|((?=.*[a-z])(?=.*[!@#$%^&*? ])).*$/;
//输出 true  
console.log("=="+pPattern.test("iFat3#")); 

3. 整数正则

//正整数正则  
var posPattern = /^\d+$/;  
//负整数正则  
var negPattern = /^-\d+$/;  
//整数正则  
var intPattern = /^-?\d+$/;  
//输出 true  
console.log(posPattern.test("42"));  
//输出 true  
console.log(negPattern.test("-42"));  
//输出 true  
console.log(intPattern.test("-42"));

4. 数字正则(可以是整数也可以是浮点数)

//正数正则  
var posPattern = /^\d*\.?\d+$/;  
//负数正则  
var negPattern = /^-\d*\.?\d+$/;  
//数字正则  
var numPattern = /^-?\d*\.?\d+$/;  
console.log(posPattern.test("42.2"));  
console.log(negPattern.test("-42.2"));  
console.log(numPattern.test("-42.2")); 

5. Email正则

//Email正则  
var ePattern = /^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/;  
//输出 true  
console.log(ePattern.test(<a href="mailto:65974040@qq.com" rel="nofollow" target="_blank">65974040@qq.com</a>));

6. 手机号码正则

//手机号正则  
var mPattern = /^((13[0-9])|(14[5|7])|(15([0-3]|[5-9]))|(18[0,5-9]))\d{8}$/;  
//输出 true  
console.log(mPattern.test("18600000000"));  

7. 身份证号正则

//身份证号(18位)正则  
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]$/;  
//输出 true  
console.log(cP.test("11010519880605371X"));  

8. URL正则:

((http|ftp|https)://)(([a-zA-Z0-9\._-]+\.[a-zA-Z]{2,6})|([0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}))(:[0-9]{1,4})*(/[a-zA-Z0-9\&%_\./-~-]*)?
赤:协议
橙:字母host,前半部分(+号及以前)host、二级域名,后半部分表示一定有类似.cn、.com、.net的跟在后面
黄:域名
绿:IP host,可以进一步简化([0-9]{1,3}(\.[0-9]{1,3}){3})
橙、绿组合成hostname
青:端口
蓝:/path及后面内容,第一个/匹配host后紧跟的斜杠,host后可能有 // 后可能还有n多字符,当然,也可能没有了。最后四个字符/-~-有些问题,/ASCII码为47~的为126,(ASCII码表)这之间包括了数字、大小写字母(与前面的重复),还有些如<>=?{},这些在正常的url中也会被编码的,不会出现在url中,中括号中的 - 如果不成组就表示 - 字符(一般放在中括号两边或加转义)
容易理解,可以满足大部分需求,不能匹配url+锚点、ftp有user:pass@host的情况

9. IPv4地址正则

//ipv4地址正则  
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]?)$/;  
//输出 true  
console.log(ipP.test("115.28.47.26"));  

10. 十六进制颜色正则

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

11. 日期正则

//日期正则,简单判定,未做月份及日期的判定  
var dP1 = /^\d{4}(\-)\d{1,2}\1\d{1,2}$/;  
//输出 true  
console.log(dP1.test("2017-05-11"));  
//输出 true  
console.log(dP1.test("2017-15-11"));  
//日期正则,复杂判定  
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)$/;  
//输出 true  
console.log(dP2.test("2017-02-11"));  
//输出 false  
console.log(dP2.test("2017-15-11"));  
//输出 false  
console.log(dP2.test("2017-02-29"));  

12. QQ号码正则

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

13. 微信号正则

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

14. 车牌号正则

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

15. 包含中文正则

//包含中文正则  
var cnPattern = /[\u4E00-\u9FA5]/;  
//输出 true  
console.log(cnPattern.test("42度"));

常用的表达式

  • * 匹配前面的子表达式零次或多次。例如,zo*能匹配“z”以及“zoo”。*等价于{0,}。
  • + 匹配前面的子表达式一次或多次。例如,“zo+”能匹配“zo”以及“zoo”,但不能匹配“z”。+等价于{1,}。
  • {n}n是一个非负整数。匹配确定的n次。例如,“o{2}”不能匹配“Bob”中的“o”,但是能匹配“food”中的两个o。
  • {n,} n是一个非负整数。至少匹配n次。例如,“o{2,}”不能匹配“Bob”中的“o”,但能匹配“foooood”中的所有o。“o{1,}”等价于“o+”。“o{0,}”则等价于“o*”。
  • {n,m} m和n均为非负整数,其中n<=m。最少匹配n次且最多匹配m次。例如,“o{1,3}”将匹配“fooooood”中的前三个o。“o{0,1}”等价于“o?”。请注意在逗号和两个数之间不能有空格。 常用限定匹配次数。
  • ? 当该字符紧跟在任何一个其他限制符(*,+,?,{n},{n,},{n,m})后面时,匹配模式是非贪婪的。非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。例如,对于字符串“oooo”,“o+?”将匹配单个“o”,而“o+”将匹配所有“o”。
  • .匹配除“\n”之外的任何单个字符。要匹配包括“\n”在内的任何字符,请使用像“(.|\n)”的模式。

参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值