JavaScript 正则表达式

本文最后更新于:2024年3月18日 凌晨

JavaScript 正则表达式

  • 正则表达式是由一个字符序列形成的搜索模式。
  • 当你在文本中搜索数据时,你可以用搜索模式来描述你要查询的内容。
  • 正则表达式可以是一个简单的字符,或一个更复杂的模式。
  • 正则表达式可用于所有文本搜索和文本替换的操作。

语法

1
/正则表达式主体/修饰符(可选)

实例

1
var patt = /test/i
  • /test/i 是一个正则表达式。
  • test 是一个正则表达式主体 (用于检索)
  • i 是一个修饰符 (搜索不区分大小写)

使用字符串方法

  • 在 JavaScript 中,正则表达式通常用于两个字符串方法: search()replace()
  • search() 方法用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串,并返回子串的起始位置。
  • replace() 方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。

search()方法使用正则表达式

  • 使用正则表达式搜索 “test” 字符串,且不区分大小写:
1
var str = "Hello test!";  var n = str.search(/test/i);

replace()方法使用正则表达式

  • 使用正则表达式且不区分大小写将字符串中的 Microsoft 替换为 test :
1
var str = document.getElementById("demo").innerHTML;  var txt = str.replace(/microsoft/i,"test");

使用 RegExp 对象

  • 在 JavaScript 中,RegExp 对象是一个预定义了属性和方法的正则表达式对象。

语法

1
var patt=new RegExp(pattern,modifiers);
  • 或更简单的方法。
1
var patt=/pattern/modifiers;
  • 模式描述了一个表达式模型。
  • 修饰符(modifiers)描述了检索是否是全局,区分大小写等。

注意:当使用构造函数创造正则对象时,需要常规的字符转义规则(在前面加反斜杠 ),比如,以下是等价的:

1
2
var re = new RegExp("\\w+");
var re = /\w+/;

test()

  • test()方法搜索字符串指定的值,根据结果并返回真或假。
  • 下面的示例是从字符串中搜索字符 “e” :
1
var patt1=new RegExp("e"); document.write(patt1.test("The best things in life are free"));
  • 当使用构造函数创造正则对象时,需要常规的字符转义规则(在前面加反斜杠 )
1
var re = new RegExp("\\w+");

exec()

  • exec() 方法检索字符串中的指定值,返回值是被找到的值,如果没有发现匹配,则返回 null
  • 面的示例是从字符串中搜索字符 “e” :
1
2
var patt1=new RegExp("e");
document.write(patt1.exec("The best things in life are free"));

正则表达式修饰符

  • 修饰符 可以在全局搜索中不区分大小写:
修饰符 描述
i 执行对大小写不敏感的匹配,
g 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止),
m 执行多行匹配,

正则表达式模式

  • 方括号用于查找某个范围内的字符:
表达式 描述
[abc] 查找方括号之间的任何字符,
[^abc] 查找任何不在方括号之间的字符,
[0-9] 查找任何从 0 至 9 的数字,
[a-z] 查找任何从小写 a 到小写 z 的字符,
[A-Z] 查找任何从大写 A 到大写 Z 的字符,
[A-z] 查找任何从大写 A 到小写 z 的字符,
[adgk] 查找给定集合内的任何字符,
[^adgk] 查找给定集合外的任何字符,
(red|blue|green) 查找任何指定的选项,
  • 元字符是拥有特殊含义的字符:
元字符 描述
. 查找单个字符,除了换行和行结束符,
\w 查找数字,字母及下划线,
\W 查找非单词字符,
\d 查找数字,
\D 查找非数字字符,
\s 查找空白字符,
\S 查找非空白字符,
\b 匹配单词边界,
\B 匹配非单词边界,
\0 查找 NULL 字符,
\n 查找换行符,
\f 查找换页符,
\r 查找回车符,
\t 查找制表符,
\v 查找垂直制表符,
\xxx 查找以八进制数 xxx 规定的字符,
\xdd 查找以十六进制数 dd 规定的字符,
\uxxxx 查找以十六进制数 xxxx 规定的 Unicode 字符,
  • 量词:
量词 描述
n+ 匹配任何包含至少一个 n 的字符串,例如,/a+/ 匹配 “candy” 中的 “a”,“caaaaaaandy” 中所有的 “a”,
n* 匹配任何包含零个或多个 n 的字符串,例如,/bo*/ 匹配 “A ghost booooed” 中的 “boooo”,“A bird warbled” 中的 “b”,但是不匹配 “A goat grunted”,
n? 匹配任何包含零个或一个 n 的字符串,例如,/e?le?/ 匹配 “angel” 中的 “el”,“angle” 中的 “le”,
n{X} 匹配包含 X 个 n 的序列的字符串,例如,/a{2}/ 不匹配 “candy,” 中的 “a”,但是匹配 “caandy,” 中的两个 “a”,且匹配 “caaandy.” 中的前两个 “a”,
n{X,} X 是一个正整数,前面的模式 n 连续出现至少 X 次时匹配,例如,/a{2,}/ 不匹配 “candy” 中的 “a”,但是匹配 “caandy” 和 “caaaaaaandy.” 中所有的 “a”,
n{X,Y} X 和 Y 为正整数,前面的模式 n 连续出现至少 X 次,至多 Y 次时匹配,例如,/a{1,3}/ 不匹配 “cndy”,匹配 “candy,” 中的 “a”,“caandy,” 中的两个 “a”,匹配 “caaaaaaandy” 中的前面三个 “a”,注意,当匹配 “caaaaaaandy” 时,即使原始字符串拥有更多的 “a”,匹配项也是 “aaa”,
n$ 匹配任何结尾为 n 的字符串,
^n 匹配任何开头为 n 的字符串,
?=n 匹配任何其后紧接指定字符串 n 的字符串,
?!n 匹配任何其后没有紧接指定字符串 n 的字符串,