JavaScript 正则

Posted dbf-

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript 正则相关的知识,希望对你有一定的参考价值。

修饰符

修饰符 描述
i 执行对大小写不敏感的匹配。
g 查找所有匹配而非在找到第一个匹配后停止。
m 执行多行匹配。

方括号

表达式 描述
[abc] 查找方括号之间的任何字符。
[^abc] 查找任何不在方括号之间的字符。
[0-9] 查找任何从 0 至 9 的数字。
[a-z] 查找任何从小写 a 到小写 z 的字符。
[A-Z] 查找任何从大写 A 到大写 Z 的字符。
[A-z] 查找任何从大写 A 到小写 z 的字符。
(a|b|c) 查找任何指定的选项。

元字符

元字符 描述
. 查找单个字符,除了换行和行结束符。
\w 查找单词字符。
\W 查找非单词字符。
\d 查找数字。
\D 查找非数字字符。
\s 查找空白字符。
\S 查找非空白字符。
\b 匹配单词边界。
\B 匹配非单词边界。
\0 查找 NUL 字符。
\n 查找换行符。
\f 查找换页符。
\r 查找回车符。
\t 查找制表符。
\v 查找垂直制表符。
\xxx 查找以八进制数 xxx 规定的字符。
\xdd 查找以十六进制数 dd 规定的字符。
\uxxxx 查找以十六进制数 xxxx 规定的 Unicode 字符。

量词

量词 描述
n+ 匹配任何包含至少一个 n 的字符串。
n* 匹配任何包含零个或多个 n 的字符串。
n? 匹配任何包含零个或一个 n 的字符串。
n{X} 匹配包含 X 个 n 的序列的字符串。
n{X,Y} 匹配包含 X 至 Y 个 n 的序列的字符串。
n{X,} 匹配包含至少 X 个 n 的序列的字符串。
n$ 匹配任何结尾为 n 的字符串。
^n 匹配任何开头为 n 的字符串。
?=n 匹配任何其后紧接指定字符串 n 的字符串。
?!n 匹配任何其后没有紧接指定字符串 n 的字符串。

test - 判断字符串是否符合规定的正则

rep = /\d+/;    // 是否包含数字
rep.test("abc123def")
// true
rep = /^\d+$/;  // 是否全为数字
rep.test("abc123def")
// false
rep = /^\d+$/;  // 是否全为数字
rep.test("123abc456")
// false
rep = /^\d+$/;  // 是否全为数字
rep.test("123456")
// true

exec - 获取匹配的数据

rep = /\d+/;
str = "abc123def456"
rep.exec(str)
// ["123"]
str = "javascript is more fun than Java or JavaBeans!";
var pattern = /\bJava\w*\b/;
pattern.exec(str)
// ["JavaScript"]
str = "JavaScript is more fun than Java or JavaBeans!";
var pattern = /\bJava(\w*)\b/;  // 分组匹配
pattern.exec(str)
// ["JavaScript", "Script"]
str = "JavaScript is more fun than Java or JavaBeans!";
var pattern = /\bJava\w*\b/g;   // 全局匹配
pattern.exec(str)
// ["JavaScript"]
// ["Java"]
// ["JavaBeans"]
// null
str = "JavaScript is more fun than Java or JavaBeans!";
var pattern = /\bJava(\w*)\b/g;
pattern.exec(str)
// ["JavaScript",'Script']
// ["Java", ""]
// ["JavaBeans", "Beans"]
// null

多行匹配:
默认就是多行匹配,但是将多行看成一个字符串,只有一个开头和一个结尾,使用多行匹配将每行看成一个字符串,可以匹配到多个开头和结尾(配合全局匹配)

str = "JavaScript is more fun than\nJava or JavaBeans!";
var pattern = /^\b\w*\b/gm;
pattern.exec(str)
// ["JavaScript"]
// ["Java"]
// null
str = "JavaScript is more fun than\nJava or JavaBeans!";
var pattern = /^\b\w*\b/g;
pattern.exec(str)
// ["JavaScript"]
// null

以上是关于JavaScript 正则的主要内容,如果未能解决你的问题,请参考以下文章

Javascript 清理 URL 正则表达式

JavaScript中 正则表达式的使用 及 常用正则表达式

VSCode自定义代码片段12——JavaScript的Promise对象

VSCode自定义代码片段12——JavaScript的Promise对象

30秒就能看懂的JavaScript 代码片段

通过 Java 正则表达式提取 semver 版本字符串的片段