正则表达式组成
元字符
量词元字符
用来设置出现的次数
*
代表 0 ~ ∞ 次+
代表 1 ~ ∞ 次?
代表 0 或 1 次{n}
代表出现 n 次{n,}
代表 n ~ ∞ 次{n,m}
代表 n ~ m 次
特殊元字符
单个或者组合在一起代表的特殊含义
单个
\
转义字符 ( 普通 => 特殊 => 特殊 ).
可以代表除 \n ( 换行符 ) 以外的任意字符^
以哪一个元字符匹配作为开始$
以哪一个元字符匹配作为结尾|
逻辑或字符, | 的左右两边规则都使用, \d | \ s ( 匹配一个数字或者一个空格 )[]
成员字符, 在 [ ] 中出现的的字符, [ 0-9a-z ] ( 匹配一个字符, 范围式0-9 小写字母a-z)
多个
\n
换行符\t
制表符 ( 一个Tab, 相当于4个空格 )\b
匹配一个单词的边界\d
0 ~ 9 之间的一个数\D
非 0 ~ 9 之间的一个数\w
数字, 字母, 下划线中任意一个\W
非 数字, 字母, 下划线中任意一个\s
空白字符( 空格丶制表符丶换页符等 )\S
非空白字符( 空格丶制表符丶换页符等 )[a-z]
指定范围, 范围为 a ~ z 内的任意字符 [0-9a-zA-Z_] === \w[^0-9a-z, ]
[^] 代表除了[]中的任意字符, ^为非的意思, 这里指除了 0~9 a~z 逗号 空格外的字符()
分组符号(?:)
只匹配不捕获(?=)
正向预查(?!)
负向预查
普通元字符
代表本身字符串的含义, a就是a, b就是b
let re = /today is good, hahaha, l have let it go/;
let str1 = 'today is good, hahaha, l have let it go';
let str2 = 'today is good, hahaha, l have let it';
re.test(str1) // => true
re.test(str2) // => false
修饰符
正则表达式常用的修饰符有三种 : img
-
i => ignoreCase
忽略大小写匹配 -
m => multiline
可以进行多行匹配 -
g => global
全局匹配let re1 = /AB/; // 不忽略大小写匹配 let re2 = /AB/i; // 忽略大小写匹配 let str = 'ab ab' console.log(re1.test(str)) // => false console.log(re2.test(str)) // => true