JavaScript正则表达式通过RegExp对象或字面量创建,支持test()、exec()、match()、replace()等方法实现匹配、提取与替换;字面量(如/\d+/g)简洁高效,构造函数(如new RegExp('\\d+', 'g'))适用于动态场景;常用标志包括g、i、m、u、s;需注意转义、lastIndex、捕获组及^$边界匹配。

JavaScript 用 RegExp 对象或正则字面量(如 /abc/)进行模式匹配,核心是通过 test()、exec()、match()、replace() 等方法实现查找、提取和替换。
正则表达式写法:字面量 vs 构造函数
两种创建方式,适用场景不同:
-
字面量写法:
/pattern/flags,比如/\d+/g,简洁高效,适合静态正则 -
构造函数写法:
new RegExp('pattern', 'flags'),比如new RegExp('\\d+', 'g'),适合动态拼接(注意字符串转义要双反斜杠)
常用匹配方法及区别
不同方法返回结果不同,选对很重要:
-
reg.test(str)→ 返回true或false,适合判断是否存在匹配(最轻量) -
reg.exec(str)→ 返回匹配数组(含index、input等属性),全局模式下可循环调用获取所有结果 -
str.match(reg)→ 字符串方法,非全局时类似exec;全局时返回所有匹配项组成的数组(不带额外信息) -
str.replace(reg, replacement)→ 替换匹配内容,支持字符串或函数作为替换值
标志(flags)的作用与组合
常见标志影响匹配行为:
立即学习“Java免费学习笔记(深入)”;
-
g(global):全局匹配,不加则只匹配第一个 -
i(ignoreCase):忽略大小写,如/hello/i匹配"Hello" -
m(multiline):让^和$匹配每行起止,不只是整个字符串首尾 -
u(unicode):正确处理 Unicode 字符(如 emoji、中文) -
s(dotAll):让.匹配包括换行符在内的所有字符
实用小技巧与注意事项
写正则时容易踩坑,记住这些:
- 用
\\表示字面量反斜杠,比如匹配数字加点:/\\d+\\./ - 全局正则对象有
lastIndex属性,多次调用exec会从上次位置继续,需手动重置为0或改用match - 捕获组用
(),非捕获组用(?:...)避免干扰索引 - 用
^和$严格匹配开头结尾,避免误匹配子串(如验证邮箱、手机号)
基本上就这些。正则不复杂但容易忽略细节,多试几次、打印结果看结构,很快就能上手。











