正则小记忆
元字符
. 匹配除换行符以外的任意字符
\w 匹配字母或数字或下划线或汉字
\s 匹配任意的空白符
\d 匹配数字
\b 匹配单词的开始或结束
^ 匹配字符串的开始
$ 匹配字符串的结束
重复
* 重复零次或更多次
+ 重复一次或更多次
? 重复零次或一次
{n} 重复n次
{n,} 重复n次或更多次
{n,m} 重复n到m次
[] 匹配里面的任意一个
但是如果你想匹配没有预定义元字符的字符集合(比如元音字母a,e,i,o,u),应该怎么办?
很简单,你只需要在方括号里列出它们就行了,像[aeiou]就匹配任何一个英文元音字母
分支条件
分支条件是用 | 进行区分两部分正则表达式,感觉和或的感觉很类似,满足两个部分之一就算是匹配成功
注意:使用分枝条件时,要注意各个条件的顺序。原因是匹配分枝条件时,将会从左到右地测试每个条件,如果满足了某个分枝的话,就不会去再管其它的条件了。
分组
分组用()来指定子表达式,可以重复多个符合分组表达式的字符串。
贪婪与懒惰
我感觉首先需要分清什么贪婪和什么是懒惰。对于同一个正则表达式 贪婪 就意味着最长匹配符合规则的字符串中的一段,懒惰就是和贪婪相反,最短的匹配字符串。
*? 重复任意次,但尽可能少重复
+? 重复1次或更多次,但尽可能少重复
?? 重复0次或1次,但尽可能少重复
{n,m}? 重复n到m次,但尽可能少重复
{n,}? 重复n次以上,但尽可能少重复
eg:
let str = 'aabab'
let reg = /a.*b/ //aabab
let reg1 = /a.*?b/ //aab