Flags 写在结束的/之后,可以影响整个正则表达式的匹配行为。Flags 可以组合使用。
常见的 flags 有:
g:全局匹配(global);
正则表达式默认只会返回第一个匹配结果,使用标志符g则可以返回所有匹配。
i:忽略大小写(case-insensitive);
在匹配时忽略英文字母的大小写。
m:多行匹配(multiline);
将开始和结束字符(^和$)视为在多行上工作,即分别匹配每一行(由 \n 或 \r 分割)的开始和结束,而不只是只匹配整个输入字符串的最开始和最末尾处。
用于匹配字符集合中的任意一个字符。比如匹配所有的字母和数字可以写成:/[a-zA-Z0-9]/ 或者 /[a-z0-9]/i。
常见的字符集有:
[xyz]:匹配 “x"或"y”``“z” — 比使用 (x|y|z) 的运行速度快(捕获括号存在性能损失)推荐使用[xyz]
[^xyz]:补集,匹配除 “x” “y” "z"的其他字符
[a-z]:匹配从 “a” 到 “z” 的任意字符
[^a-n]:补集,匹配除 “a” 到 “n” 的其他字符
[A-Z]:匹配从 “A” 到 “Z” 的任意字符
[0-9]:匹配从 “0” 到 “9” 的任意数字
在实际使用中常需要匹配同一类型的字符多次,比如匹配 11 位的手机号,我们不可能将 [0-9] 写 11 遍,此时可以使用 Quantifiers 来实现重复匹配。**
{n}:匹配 n 次
{n,m}:匹配 n-m 次
{n,}:匹配 >=n 次
?:匹配 0 || 1 次
*:匹配 >=0 次,等价于 {0,}
+:匹配 >=1 次,等价于 {1,}
在正则表达式中有一些具有特殊含义的字母,被称为元字符,简言之,元字符就是描述字符的字符,它用于对字符表达式的内容、转换及各种操作信息进行描述。**
\d:匹配任意数字,等价于 [0-9]
\D:匹配任意非数字字符;\d 的补集
\w:匹配任意基本拉丁字母表中的字母和数字,以及下划线;等价于 [A-Za-z0-9_]
\W:匹配任意非基本拉丁字母表中的字母和数字,以及下划线;\w 的补集
\s:匹配一个空白符,包括空格、制表符、换页符、换行符和其他 Unicode 空格
\S:匹配一个非空白符;\s的补集
\b:匹配一个零宽单词边界,如一个字母与一个空格之间;例如,/\bno/ 匹配 “at noon” 中的 “no”,/ly\b/ 匹配 “possibly yesterday.” 中的 “ly”
\B:匹配一个零宽非单词边界,如两个字母之间或两个空格之间;例如,/\Bon/ 匹配 “at noon” 中的 “on”,/ye\B/ 匹配 "possibly yesterday."中的 “ye”
\t:匹配一个水平制表符(tab)
\n:匹配一个换行符(newline)
\r:匹配一个回车符(carriage return)
\t:匹配一个水平制表符(tab)
\n:匹配一个换行符(newline)
\r:匹配一个回车符(carriage return)