1. 创建正则表达式
-
通过字面量的形式
const reg = /\w/g //匹配字母
-
通过构造函数
const reg = new Reg('\w', 'g')
2. 选择符 |
const reg = /abc|edc/g // 匹配字符串中的abc 或 edc
3. 原子组和原子表
-
原子组 () 正则会为原子组进行编号使用/1、/2等使用
- 在原子组里使用:?表示该原子组不记录进组编号内,也就是说使用exec方法是获取不到该原子组匹配的内容
const reg = /(abcdefg)/ //匹配字符串abcdefg
原子组里可以使用选择符 |
const reg = /(abc|edc )/
-
原子表 []
- 原子表里使用. + 等特殊字符不需要转义,也意味着原子表里面无法使用.来匹配非空格字符
const reg = /[abcdefg]/ //匹配abcdefg里任意一字符 let str = "2022-(/)01-(/)01" //需要匹配的字符串 let reg = /^\d{4}[-\/]\d{2}[-\/]\d{2}$/g let reg2 = /^\d{4}([-\/])\d{2}\1\d{2}$/g //这里的\1指与上个原子组保持一致,相当于前面的原子组里的是什么后面的就匹配什么
4. 转义符 \
- 大多数符号都需要配合使用 \ 进行转义
const reg = /\d+\.\d+/ // 匹配浮点数
- 作为对象的参数时,与使用两个\
const reg = new RegExp("\\d+\\.\\d+") //匹配浮点数
5. 字符边界^ $
^起始边界 、$结束边界
const reg = /^[a-z]{3,6}$/ // 匹配以字母a-z为开头a-z为结尾中间为a-z的长度为3到6w
6. 元字符
- \d 匹配数字
- \D 匹配非数字
- \w 匹配字母、数字、下划线
- \W 匹配非字母、数字、下划线
- \s 匹配空格、换行等
- \S 匹配非空格、换行等
- . 匹配换行符之外的所有字符
7. 模式修饰符
g 全局匹配
s忽略换行符
i 不区分大小写
-
m多行匹配
const reg = /^\s*#\d+\s+.+\s+#$/gm
8. 汉字与字符属性
const reg1 = /\p{L}/gu //匹配字母
const reg2 = /\p{P}/gu //匹配标点符号
const reg3 = /\p{sc=Han}/gu //匹配汉字
9. lastIndex属性
-
正则匹配后的最新的匹配项
let reg = /\w/g; while ((res = reg.exec((hd)))) { console.log(res); }
10.区间匹配
[a-z]匹配a到z 之间的任意字母,加+为贪婪匹配
[A-Z]匹配A到Z之间的任意字母, 加+为贪婪匹配
[^abc] 匹配非abc的所有字符
11.匹配所有内容
- /.+/gs 匹配所有内容
- /[\s\S]/ 匹配所有内容 [\d\D]与[\w\W]类似
12.重复匹配
- ?匹配一个或0个
- *匹配0个或多个 (贪婪匹配)
- +匹配一个或多个
- {number, number} 匹配指定区间个数个
邮箱验证
let reg = /^[\w-]+@([\w-]+\.)+(com|org|cc|cn|net)$/i
// 12345678@qq.com