通用字符组(匹配任意单个字符)
通用字符组 | 表达含义 |
---|---|
\d | 任意数字符号 |
\D | 非数字符号 |
\w | 字母和数字符号(单词符号) |
\W | 非字母和数字符号 |
\s | 任意空白符号(空格,制表符,换行符等类似符号) |
\S | 非空白符号 |
. | 除了换行符以外的任意字符 |
特殊字符
特殊字符 | 表达含义 |
---|---|
- | 连字符,指定一个字符范围 |
^ | 脱字符,置于元素前,表示字符串起始位置 |
$ | 表示字符串结束位置 |
+ | 置于元素后,表示该元素重复一次或多次 |
* | 置于元素后,表示该元素重复零次或者多次 |
? | 置于元素后,表示该部分模式可选,即出现0次或者1次;当该字符紧跟在任何一个其他限制符 (*, +, ?, {n}, {n,}, {n,m}) 后面时,匹配模式是非贪婪的。非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。 |
\b | 字符边界 |
| | 逻辑或,/\d+|abc/ 表示匹配任意数字字符或者匹配字母集abc |
特殊字符之"^"
如上图:
- "^"这个字符在中括号”[]”中使用的话表示字符类的否定,即不匹配这组字符集中的所有字符。这里说的是直接在”[]”中使用,不包括嵌套使用。 也就说”[]”代表的是一个字符集,”^”只有在字符集中才是反向字符集的意思。
- 如果不在中括号”[]”中直接使用的话就表示限定开头,即/^2/表示以2开头
特殊字符之"\b"
- \b 可以放在正则表达式的开头或末尾,分别表示起始边界和结束边界,\b 修饰其后或其之前的所有字符。如上图:/\b12/ 表示匹配以12开头的字符集,/12\b/ 表示匹配以12结尾的字符集。
- \b 可以匹配字母、数字、汉字和下划线。
- \b 同时出现在正则表达式开头和末尾表示绝对匹配,即字符集和正则表达式中的完全一致才为真。
正则表达式中的括号
括号 | 表达含义 |
---|---|
() | () 内的内容表示的是一个子表达式,() 本身不匹配任何东西,也不限制匹配任何东西,只是把括号内的内容作为同一个表达式来处理。比如 /ab+/ 中 + 字符仅仅修饰 b,即 b 重复一次或多次;而 /(ab)+/ 中 ab 作为一个整体被 + 修饰,即 ab 重复一次或多次。 |
[] | [] 表示匹配 [] 中的任意字符,并且特殊字符写在 [] 会被当成普通字符来匹配。比如 /[(a+)]/ 表示匹配 "("、"a"、"+"、")" 四个字符中的任意一个。 |
{} | {} 一般用来表示匹配的长度,即某个模式出现的次数或次数范围。比如,在某个元素后加上 {4},表示该元素需要出现且只能出现4次;而 {2,4} 表示该元素至少出现2次,至多出现4次,{,5} 表示0到5次,{5,} 表示至少5次。 |
字符串replace方法中的 g 选项和 i 选项
-
如上:字符串有一个replace方法,用于将字符串中的一部分替换为另一个字符串,但是只能替换第一个匹配项,而JavaScript不存在replaceAll方法。
-
如上:replace方法的第一个参数可以是正则表达式,默认情况下也只会替换首先匹配的项,若在正则表达式后追加 g 选项(/p/g),则会替换字符串的所有匹配项。
如上:正则表达式后面的 i 选项表示不区分大小写,gi 表示不区分大小写且全局替换。
正则表达式中的断言:用于查找某些元素之前或之后的内容
-
?=pattern:零宽正向先行断言,要求已匹配字符序列之后的字符序列能够匹配pattern。如下正则表示匹配一个或多个非空格、=、;的字符,且该字符序列后面是=。
-
?<=pattern:零宽正向后行断言,要求已匹配字符序列的前面能够匹配pattern。如下正则表示匹配前面是=号,非空格、=、;的字符序列。
- ?!pattern:零宽负向先行断言,要求已匹配字符序列的后面不能匹配pattern。
- ?<!pattern:零宽负向后行断言,要求已匹配字符序列的前面不能匹配pattern。
其他(不常见)
正则表达式的exec方法以及字符串的match方法
其他正则表达式的符号请参考:https://www.cnblogs.com/yirlin/archive/2006/04/12/373222.html