常用的正则表达式(持续更新中...)

常用的正则匹配归纳

1、匹配中文

 [\u4e00-\u9fa5]

2、英文字母

[a-zA-Z]

3、数字

[0-9]

4、匹配中文,英文字母和数字及下划线

^[\u4e00-\u9fa5_a-zA-Z0-9]+$

同时判断输入长度

[\u4e00-\u9fa5_a-zA-Z0-9_]{4,10}

5、不能以特定字符开头结尾

(?!_)  不能以_开头(?!.*?_$)  不能以_结尾

6、至少一个汉字、数字、字母、下划线

[a-zA-Z0-9_\u4e00-\u9fa5]+

7、与字符串结束的地方匹配

$

8、只含有汉字、数字、字母、下划线,下划线位置不限

^[a-zA-Z0-9_\u4e00-\u9fa5]+$

9、由数字、26个英文字母或者下划线组成的字符串

^\w+$

10、2~4个汉字

^[\u4E00-\u9FA5]{2,4}$

11、最长不得超过7个汉字,或14个字节(数字,字母和下划线)正则表达式

^[\u4e00-\u9fa5]{1,7}$|^[\dA-Za-z_]{1,14}$

12、匹配双字节字符(包括汉字在内)

[^x00-xff]

13、匹配空白行

ns*r
n[s| ]*r

14、匹配HTML标记

]*>.*?|<.>
/.*|/

15、匹配首尾空白字符

^s*|s*
(^s*)|(s*$)

16、匹配Email地址

^[a-zA-Z0-9][\w\.-]*[a-zA-Z0-9]@[a-zA-Z0-9][\w\.-]*[a-zA-Z0-9]\.[a-zA-Z][a-zA-Z\.]*[a-zA-Z]$
^w+[-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$
w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*

17、手机号

^((13[0-9])|(14[0-9])|(15[0-9])|(17[0-9])|(18[0-9]))\d{8}$

18、身份证

(^\d{15}$)|(^\d{17}([0-9]|X|x)$)d{15}|d{18}
// 验证身份证号(15位或18位数字)
^d{15}|d{}18$

19、匹配网址URL

[a-zA-z]+://[^s]*
http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?
// 验证InternetURL
^http://([w-]+.)+[w-]+(/[w-./?%&=]*)?$

20、匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线)

^[a-zA-Z][a-zA-Z0-9_]{4,15}$

21、匹配国内电话号码

// 如 0511-4405222 或 021-87888822
d{3}-d{8}|d{4}-d{7}

22、匹配腾讯QQ号

// 从10000开始
[1-9][0-9]{4,}

23、匹配ip地址

d+.d+.d+.d+

24、验证一年的12个月

// 正确格式为:“01”-“09”和“1”“12”
^(0?[1-9]|1[0-2])$

25、验证一个月的31天

// 正确格式为:“01”“09”和“1”“31”
^((0?[1-9])|((1|2)[0-9])|30|31)$

26、匹配双字节字符(包括汉字在内)

[^x00-xff]

27、匹配特定数字

// 匹配正整数
^[1-9]d*$

// 匹配负整数
^-[1-9]d*$

// 匹配整数
^-?[1-9]d*$

// 匹配非负整数(正整数 + 0)
^[1-9]d*|0$

// 匹配非正整数(负整数 + 0)
^-[1-9]d*|0$

// 匹配正浮点数
^[1-9]d*.d*|0.d*[1-9]d*$

// 匹配负浮点数
^-([1-9]d*.d*|0.d*[1-9]d*)$

// 匹配浮点数
^-?([1-9]d*.d*|0.d*[1-9]d*|0?.0+|0)$

// 匹配非负浮点数(正浮点数 + 0)
^[1-9]d*.d*|0.d*[1-9]d*|0?.0+|0$

// 匹配非正浮点数(负浮点数 + 0)
^(-([1-9]d*.d*|0.d*[1-9]d*))|0?.0+|0$

28、匹配特定字符串

// 匹配由26个英文字母组成的字符串
^[A-Za-z]+$

// 匹配由26个英文字母的大写组成的字符串
^[A-Z]+$

// 匹配由26个英文字母的小写组成的字符串
^[a-z]+$

// 匹配由数字和26个英文字母组成的字符串
^[A-Za-z0-9]+$

// 匹配由数字、26个英文字母或者下划线组成的字符串
^w+$
1、必须以字母或中文开头,可以包含数字、下划线或“.”、“-”。
// 在reactJS上的写法
 const value = '测试haha';
 const reg = '^[\u4E00-\u9FA5A-Za-z][\u4E00-\u9FA5A-Za-z0-9_.!-、]*$';
 if (!value) {return false;}
 const val = value.match(reg, '');
 if (val !== null && val !== '') {
   console.log('验证成功!');
 } else {
   console.log('请检查填写是否符合规范!');
 }
2、密码:必须同时包含大写英文字母、小写英文字母、数字和特殊字符中的三项。 支持的特殊字符如下:!@#$%^&*()_±=
// 用几个条件判断更简单些
function demo (str) {
  var count = 0;
  if(/\p{Unified_Ideograph}/u.test(str)) {
    return console.log('不允许输入汉字')
  }
  if(/\d/.test(str)) count++
  if(/[a-z]/.test(str)) count++
  if(/[A-Z]/.test(str)) count++
  if(/[@#$%^&*()_+!-=]/.test(str)) count++
  if(count < 4) {
    console.log('需包含大写字母,小写字母、数字、特殊符号中的三类及以上')
  } else {
    console.log('验证成功')
  }
}
console.log(demo('q32&23='))
3、允许使用点号(.)分割字符成多段,每段允许使用大小写英文字母、数字和连字符(-),但不能连续使用点号(.)或连字符(-),不能以点号(.)或连字符(-)开头或结尾
// 在reactJS上的写法
const value = '测试haha';
const reg = '^(?![.-])(?!.*[.-]{2})[a-zA-Z0-9.-]{2,64}(?<![.-])$';
 const val = value.match(reg, '');
 if (val !== null && val !== '') {
   console.log('验证成功!');
 } else {
   console.log('请检查填写是否符合规范!');
 }

扩展

正则表达式生成器:https://c.runoob.com/front-end/854/?optionGlobl=global

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值