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

开发 前端
本文介绍了正则表达式中的基本用法,在日常开发中基本就够用了。正则很强大,但是也不能滥用。如果你写出了一个很复杂的只有你能看懂的正则,更好的做法是不使用正则去实现它。

1. 概览

 在 JavaScript 中,使用 // 即可创建一个正则表达式对象,当然也可以使用 new RegExp()

常用的跟正则相关的方法有 match、test 和 replace。

其中 match,replace 都是字符串上的方法, test 是正则对象上的方法。

下面看具体的图示:

 

2. 匹配单字符

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

3. 正则选项

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

  1. i - 代表忽略大小写
  2. m - 代表多行匹配
  3. g - 代表全局匹配(可以匹配多次)

 

4. 边界匹配

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

 

5. 字符匹配

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

 

6. 量词匹配

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

 

7. 分组

() 小括号在正则中代表分组,一般在 match 方法中用来返回全匹配加上多个分组结果,如果使用了 g 选项,则只返回全匹配。

在小括号中你可以使用管道符号 |,它代表或

 

8. 特殊字符

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

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

所以如果你需要匹配星号 *,就需要这样写:

\*

 

9. 取非匹配

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

至此 ^ 具有两个含义:

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

 

10. 完

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

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

 

责任编辑:庞桂玉 来源: segmentfault
相关推荐

2009-02-18 09:48:20

正则表达式Java教程

2009-08-17 13:56:28

C#正则表达式入门

2010-03-01 15:51:59

Python则表达式

2019-12-10 10:40:57

Python正则表达式编程语言

2018-09-27 15:25:08

正则表达式前端

2010-07-22 09:12:05

Perl正则表达式

2020-09-04 09:16:04

Python正则表达式虚拟机

2010-02-24 17:13:47

2022-01-04 11:35:03

Linux Shel正则表达式Linux

2016-11-10 16:21:22

Java 正则表达式

2023-09-13 08:12:45

2009-09-16 17:15:57

正则表达式引擎

2010-03-25 18:25:36

Python正则表达式

2009-08-07 14:24:31

.NET正则表达式

2009-09-16 18:19:34

正则表达式组

2017-05-12 10:47:45

Linux正则表达式程序基础

2019-07-17 15:45:47

正则表达式字符串前端

2022-03-28 06:19:14

正则表达式开发

2011-06-02 12:34:16

正则表达式

2021-01-27 11:34:19

Python正则表达式字符串
点赞
收藏

51CTO技术栈公众号