普通字符
[ABC] 匹配 […] 中的所有字符
[^ABC] 匹配除了 […] 中字符的所有字符
[A-Z] 表示一个区间
[\s\S] 匹配所有。\s 是匹配所有空白符,包括换行,\S 非空白符,不包括换行。
\w 匹配字母、数字、下划线。等价于 [A-Za-z0-9_]
非打印字符
\n 匹配一个换行符。
\s 匹配任何空白字符,包括空格、制表符、换页符等等。等价于 [ \f\n\r\t\v]。
\S 匹配任何非空白字符。等价于 [^ \f\n\r\t\v]。
\t 匹配一个制表符
特殊字符
$ 匹配输入字符串的结尾位置。
^ 匹配输入字符串的开始位置。
[ 标记一个中括号表达式的开始.
( ) 标记一个子表达式的开始和结束位置。
{ 标记限定符表达式的开始。
| 指明两项之间的一个选择。
. 匹配除换行符 \n 之外的任何单字符。
限定符
* 匹配前面的子表达式零次或多次。
+ 匹配前面的子表达式一次或多次.
? 匹配前面的子表达式零次或一次
{n} n 是一个非负整数。匹配确定的 n 次
{n,} n 是一个非负整数。至少匹配n 次
{n,m} 最少匹配 n 次且最多匹配 m 次
* 和 + 限定符都是贪婪的,因为它们会尽可能多的匹配文字,只有在它们的后面加上一个 ? 就可以实现非贪婪或最小匹配。
/<.>/ 贪婪:下面的表达式匹配从开始小于符号 (<) 到关闭 h1 标记的大于符号 (>) 之间的所有内容。
/<.?>/或者/<\w+?>/ 非贪婪:只匹配开始和结束标签,下面的非贪婪表达式只匹配到第一个 >。
通过在 *、+ 或 ? 限定符之后放置 ?,该表达式从"贪婪"表达式转换为"非贪婪"表达式或者最小匹配
定位符
^ 匹配输入字符串开始的位置
$ 匹配输入字符串结尾的位置
\b 匹配一个单词边界,即字与空格间的位置
\B 非单词边界匹配
exp1(?=exp2):查找 exp2 前面的 exp1。
(?<=exp2)exp1:查找 exp2 后面的 exp1。
exp1(?!exp2):查找后面不是 exp2 的 exp1。
(?<!exp2)exp1:查找前面不是 exp2 的 exp1。
修饰符(标记)
/pattern/flags
i ignore 不区分大小写 将匹配设置为不区分大小写,搜索时不区分大小写: A 和 a 没有区别。
g global 全局匹配 查找所有的匹配项。
m multi line -多行匹配 使边界字符 ^ 和 $ 匹配每一行的开头和结尾,记住是多行,而不是整个字符串的开头和结尾。
s 特殊字符圆点 . 中包含换行符 \n 默认情况下的圆点 . 是匹配除换行符 \n 之外的任何字符,加上 s 修饰符之后, . 中包含换行符 \n。