. 匹配除换行符以外的任意字符 \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