查看地址:http://www.runoob.com/js/js-regexp.html
一、正则表达式概述
正则表达式(英语:Regular Expression,在代码中常简写为regex、regexp或RE)使用单个字符串来描述、匹配一系列符合某个句法规则的字符串搜索模式。
搜索模式可用于文本搜索和文本替换。
二、正则表达式语法
/正则表达式主体/修饰符(可选)
示例:var patt = /runoob/i
三、正则表达式修饰符
修饰符 | 描述 | |
---|---|---|
i | intensity | 执行对大小写不敏感的匹配。 |
g | global | 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。 |
m | multiple | 执行多行匹配。检测字符串中的换行符,主要是影响字符串开始标识符^ 和结束标识符$ 的使用 |
四、正则表达式模式
^ //指出一个字符串的开始 $ //指出一个字符串的结束 [] //用于查找某个范围内的字符
| //或 模式
特殊字符:
使用转义字符即可。如var reg=///;匹配一个正斜杠
正则中有特别含义的字符匹配,都需要来转义,如: . * ^ & [ ] { } ? 等
注意:如果在[]字符集合里,很多字符都不需要转义
4.1、量词
量词 | 理解 | 描述 |
---|---|---|
n+ |
>=1 |
匹配一个或多个n 的字符串。 例如,/a+/ 匹配 "candy" 中的 "a","caaaaaaandy" 中所有的 "a"。 |
n* |
>=0 |
匹配零个或多个 n 的字符串。 例如,/bo*/ 匹配 "A ghost booooed" 中的 "boooo","A bird warbled" 中的 "b",但是不匹配 "A goat grunted"。 |
n? |
=0或=1 |
匹配零个或一个 n 的字符串。 例如,/e?le?/ 匹配 "angel" 中的 "el","angle" 中的 "le"。 |
n{X} |
按照闭区间集合 =X |
匹配包含 X 个 n 的序列的字符串。 例如,/a{2}/ 不匹配 "candy," 中的 "a",但是匹配 "caandy," 中的两个 "a",且匹配 "caaandy." 中的前两个 "a"。 |
n{X,} |
按照闭区间集合 >=X |
X 是一个正整数。前面的模式 n 连续出现至少 X 次时匹配。 例如,/a{2,}/ 不匹配 "candy" 中的 "a",但是匹配 "caandy" 和 "caaaaaaandy." 中所有的 "a"。 |
n{X,Y} | >=X,<=Y |
X 和 Y 为正整数。前面的模式 n 连续出现至少 X 次,至多 Y 次时匹配。 例如,/a{1,3}/ 不匹配 "cndy",匹配 "candy," 中的 "a","caandy," 中的两个 "a",匹配 "caaaaaaandy" 中的前面三个 "a"。注意,当匹配 "caaaaaaandy" 时,即使原始字符串拥有更多的 "a",匹配项也是 "aaa"。 |
n$ | 以n结尾 | 匹配任何结尾为 n 的字符串。 |
^n | 以n开头 | 匹配任何开头为 n 的字符串。 |
?=n | 匹配任何其后紧接指定字符串 n 的字符串。 | |
?!n | 匹配任何其后没有紧接指定字符串 n 的字符串。 |
4.2、元字符
(Metacharacter)是拥有特殊含义的字符:
元字符 | 等同于 | 描述 |
---|---|---|
. | 查找单个字符,除了换行和行结束符。 | |
w | [a-zA-Z0-9] | 查找单词字符。 |
W | [^a-zA-Z0-9] | 查找非单词字符。 |
d | [0-9] | 查找数字。 |
D | [^0-9] | 查找非数字字符。 |
s | fx0B | 查找空白字符。 |
S | ^ fx0B | 查找非空白字符。 |
匹配单词边界。 | ||
B | 匹配非单词边界。 | |