常用的正则匹配归纳
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