掌握JavaScript正则表达式高级技巧可高效处理文本,捕获组()与反向引用\1、命名捕获提升可读性;前瞻(?=...)与后瞻(?
JavaScript 正则表达式提供了强大的文本匹配能力,除了基础的字符匹配外,高级模式能处理更复杂的场景。掌握这些技巧,可以高效完成数据验证、文本提取和替换等任务。
使用括号 () 可以创建捕获组,将匹配的一部分保存起来,供后续使用。反向引用通过 \1、\2 等编号引用前面的捕获内容。
例如,匹配重复单词:
const regex = /\b(\w+)\s+\1\b/g;这里 \1 引用第一个捕获组的内容。也可命名捕获组,提高可读性:
const regex = /\b(?word>\w+)\s+\k断言用于判断某个位置前后是否满足条件,但不包含在匹配结果中。
例如,提取金额数字但不包括货币符号:
const regex = /(? "Price: $45".match(regex)[0]; // "45"或匹配不以“test”开头的单词:
const regex = /\b(?!test)\w+\b/g;默认情况下,量词如 *、+ 是贪婪的,尽可能多地匹配。添加 ? 变
为惰性匹配。
例如,提取 HTML 标签内的内容:
const greedy = /.*/;修饰符改变正则行为:
例如,跨行提取注释:
const regex = /\/\*.*?\*\//gs;基本上就这些关键点。灵活组合捕获、断言和修饰符,能让正则应对大多数复杂文本处理需求。不复杂但容易忽略的是边界情况和性能,建议在实际使用前充分测试。