写给前端的正则表达式入门
2013 年 6 月 16 日
1. 概览
在 JavaScript 中,使用 // 即可创建一个正则表达式对象,当然也可以使用 new RegExp()
常用的跟正则相关的方法有 match 、 test 和 replace 。
其中 match , replace 都是字符串上的方法, test 是正则对象上的方法。
下面看具体的图示:

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

3. 正则选项
正则对象的后面也可以跟选项, JavaScript 中常用的选项有:
i m g

4. 边界匹配
^ $

5. 字符匹配
-
.– 可以匹配除了换行符外的任意字符 -
\d– 可以匹配任意数字 -
\D– 可以匹配任意 非 数字 -
\s– 匹配任意空白字符 -
\S– 匹配任意 非 空白字符 -
\n– 匹配换行 -
\w– 它其实就等同于[A-Za-z0-9_],即匹配字母数字下划线

6. 量词匹配
*
+
?
{3}
{2,4}
{2,}

7. 分组
() 小括号在正则中代表分组,一般在 match 方法中用来返回全匹配加上多个分组结果,如果使用了 g 选项,则只返回全匹配。
在小括号中你可以使用管道符号 | ,它代表 或

8. 特殊字符
匹配特殊符号的时候需要加反斜杠 \
JS 中的特殊字符有 ^ $ \ . * + ? () [] {} |
所以如果你需要匹配星号 * ,就需要这样写:
\*

9. 取非匹配
匹配除了某个字符的任意字符,需要在中括号 [] 中使用 ^
至此 ^ 具有两个含义:
[]

10. 完
上面只是介绍了正则表达式中的基本用法,在日常开发中基本就够用了。更深入的用法比如 贪婪和懒惰 、 零宽断言 和 捕获 ,感兴趣的小伙伴可以自行学习~
正则很强大,但是也不能滥用。如果你写出了一个很复杂的只有你能看懂的正则,更好的做法是不使用正则去实现它~
参考链接
本文由savokiss 创作,采用 知识共享署名4.0 国际许可协议进行许可
本站文章除注明转载/出处外,均为本站原创或翻译,转载前请务必署名
最后编辑时间为: Nov 28, 2019 at 02:46 pm