写给前端的正则表达式入门

1. 概览

JavaScript 中,使用 // 便可建立一个正则表达式对象,固然也可使用 new RegExp()html

经常使用的跟正则相关的方法有 matchtestreplace
其中 matchreplace 都是字符串上的方法, test 是正则对象上的方法。web

下面看具体的图示:正则表达式

1.png

2. 匹配单字符

  1. /reg/ 能够直接匹配具体的字符串 reg
  2. /[arzy]/ 中的中括号[] 则表明匹配 arzy 中的任意单个字符
  3. /[f-h]/ 中的中杠 - 表明匹配字母表顺序中 fh 中的任意单个字符
  4. /[1-3]/ 则表明匹配数字 1 到 3

2.png

3. 正则选项

正则对象的后面也能够跟选项,JavaScript 中经常使用的选项有:学习

  1. i - 表明忽略大小写
  2. m - 表明多行匹配
  3. g - 表明全局匹配(能够匹配屡次)

3.png

4. 边界匹配

  1. ^ - 表明匹配字符串的开头
  2. $ - 表明匹配字符串的结尾

4.png

5. 字符匹配

  1. . - 能够匹配除了换行符外的任意字符
  2. \d - 能够匹配任意数字
  3. \D - 能够匹配任意数字
  4. \s - 匹配任意空白字符
  5. \S - 匹配任意空白字符
  6. \n - 匹配换行
  7. \w - 它其实就等同于 [A-Za-z0-9_],即匹配字母数字下划线

5.png

6. 量词匹配

  1. * - 匹配 0 次或屡次
  2. + - 匹配 1 次或屡次
  3. ? - 匹配 0 次或 1 次
  4. {3} - 匹配 3 次
  5. {2,4} - 匹配 二、3 或 4 次
  6. {2,} - 匹配 2 次或屡次

6.png

7. 分组

() 小括号在正则中表明分组,通常在 match 方法中用来返回全匹配加上多个分组结果,若是使用了 g 选项,则只返回全匹配。spa

在小括号中你可使用管道符号 |,它表明code

7.png

8. 特殊字符

匹配特殊符号的时候须要加反斜杠 \ regexp

JS 中的特殊字符有 ^ $ \ . * + ? () [] {} |htm

因此若是你须要匹配星号 *,就须要这样写:对象

\*blog

8.png

9. 取非匹配

匹配除了某个字符的任意字符,须要在中括号[] 中使用 ^

至此 ^ 具备两个含义:

  1. 若是用于正则表达式的开头,表明匹配字符串的开头
  2. 若是用于中括号 [] 内部,则表明匹配非此字符

9.png

10. 完

上面只是介绍了正则表达式中的基本用法,在平常开发中基本就够用了。更深刻的用法好比 贪婪和懒惰零宽断言捕获 ,感兴趣的小伙伴能够自行学习~

正则很强大,可是也不能滥用。若是你写出了一个很复杂的只有你能看懂的正则,更好的作法是不使用正则去实现它~

参考连接

欢迎关注个人公众号:码力全开(codingonfire)

关注并回复 副业, 获取技术人的副业秘籍

codingonfire.jpg

相关文章
相关标签/搜索