标签:匹配 重复 尽可能少 正则 记忆 条件 字符串 let
元字符
. 匹配除换行符以外的任意字符
\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
标签:匹配,重复,尽可能少,正则,记忆,条件,字符串,let 来源: https://www.cnblogs.com/Paul-Yellow/p/14665733.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。