正则小记忆

元字符

.  匹配除换行符以外的任意字符

w 匹配字母或数字或下划线或汉字

s 匹配任意的空白符

d  匹配数字

  匹配单词的开始或结束

^  匹配字符串的开始

$  匹配字符串的结束

重复

*  重复零次或更多次

+  重复一次或更多次

? 重复零次或一次

{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

原文地址:https://www.cnblogs.com/Paul-Yellow/p/14665733.html