系统总结一下目前用到过的正则表达式的知识,慢慢补充
RegExp 对象
正则表达式是描述字符模式的对象
用于对字符串模式匹配及检索替换,是对字符串执行模式匹配的工具
语法
1 | // pattern(模式) modifiers(修饰符) |
修饰符
修饰符 | 描述 |
---|---|
i | 忽略大小写 |
g | 全局匹配,查找所有匹配而不是找到第一个匹配就停止 |
m | 执行多次匹配 |
括号
用于查找某个范围内的字符:
表达式 | 描述 | ||
---|---|---|---|
[abc] | 查找方括号之间任何字符 | ||
[\^abc] | []中的\^表示排除,查找任何不在方括号内的字符 | ||
[0-9] | 查找0-9的数字 | ||
[a-z] | 查找a-z的小写字符 | ||
[A-Z] | 查找A-Z的大写字符 | ||
(red\ | blue\ | green) | 查找任何指定的选项 |
元字符
拥有特殊含义的字符:
元字符 | 描述 |
---|---|
\ | 将下一个字符标记为一个特殊字符,’\n’ 匹配一个换行符。序列 ‘\‘ 匹配 “\” 而 “(“ 则匹配 “(“ |
. | 查找单个字符,除了换行和结束符 |
\w | 查找单词字符 |
\W | 查找非单词字符 |
\d | 查找数字 |
\D | 查找非数字 |
量词
量词 | 描述 |
---|---|
^n | 匹配开头为n的字符串 |
n$ | 匹配结尾为n的字符串 |
n* | 匹配前面的子表达式0-n次 |
n+ | 匹配前面的子表达式1-n次 |
n? | 匹配前面的子表达式0-1次 |
? | 当该字符紧跟在任何一个其他限制符 (*, +, ?, {n}, {n,}, {n,m}) 后面时,匹配模式是非贪婪的。非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。例如,对于字符串 “oooo”,’o+?’ 将匹配单个 “o”,而 ‘o+’ 将匹配所有 ‘o’。 |
?=n | 匹配任何其后紧接指定字符串 n 的字符串。 |
?!n | 匹配任何其后没有紧接指定字符串 n 的字符串。 |
n{x} | 匹配包含x个n的序列的子串 |
n{x,} | X 是一个正整数。前面的模式 n 连续出现至少 X 次时匹配。 |
n{x,y} | X 和 Y 为正整数。前面的模式 n 连续出现至少 X 次,至多 Y 次时匹配。 |
RegExp 对象方法
1.exec()方法:可以进行模式匹配并返回结果
如果成功匹配,则返回一个数组;如果没有成功匹配的字符串部分,则返回null。组返回的到底是什么呢?
1 | var re = new RegExp("[?#&]" + 'user' + "=([^&#]*)", "i"); |
这段代码进行了一个url的匹配,可以用来获得user=后面的参数部分,result为:[?user=Tom, Tom]。
可以看到返回数组的第一个元素就是整个的匹配模式所匹配到的字符串,而第二个匹配到的字符恰好是参数值。
这是exec匹配返回的规则:
第一个元素为整个的匹配字符串,从第二个参数开始返回模式中每一个()所定义的分组所匹配的字符串。这里面([\^&#]*)返回的就是不以&或#开头的字符串,即后面对应的参数。
如果我们将定义的模式修改为”[?#&]” + (user) + “=([\^&#]*),那么exec()后返回的数组就是[?user=Tom, user, Tom]。