登录
首页 >  文章 >  前端

JavaScript正则表达式使用教程

时间:2026-02-18 22:24:45 361浏览 收藏

本文深入浅出地讲解了JavaScript正则表达式的实用核心:强调以test()快速判断匹配存在性、用match()或exec()精准提取内容,并反复提醒开发者优先考虑includes()/indexOf()等更简单安全的替代方案;同时系统剖析了常见陷阱——如特殊字符未转义、标志(g/i/m/s)误用、贪婪匹配失控,并给出可落地的调试建议:善用注释、拆分逻辑、动态构造正则,真正聚焦于写出稳定、可读、易维护的高质量正则代码。

javascript正则表达式怎样匹配文本?【教程】

JavaScript 正则表达式匹配文本,核心就一条:用 test() 判断是否存在匹配,用 match()exec() 提取内容。别一上来就写复杂模式,先确认是否真需要正则——简单字符串查找用 includes()indexOf() 更快更安全。

怎样用 test() 快速判断是否匹配

test() 是最轻量的匹配方式,返回布尔值,适合做条件分支。它不关心匹配多少次、在哪匹配,只回答“有没有”。

  • 必须传入字符串,传 nullundefined 会报 TypeError: Cannot read property 'toString' of null
  • 正则对象带 g 标志时,test() 会维护内部 lastIndex,连续调用可能漏匹配——除非你明确需要粘性匹配,否则避免对同一正则反复调用 test()
  • 示例:/\d+/.test("abc123def")true/^hello$/.test("hello world")false(因为 ^$ 锁定首尾)

提取匹配内容该选 match() 还是 exec()

match() 是字符串方法,exec() 是正则方法,行为差异直接影响结果结构和复用逻辑。

  • "a1b2c3".match(/\d/g) 返回数组 ["1", "2", "3"];不加 g 时返回包含 indexinput 的详细对象,但只取第一个匹配
  • /\d/.exec("a1b2c3") 总是返回第一个匹配的详细对象(含 index),且每次调用后 lastIndex 自动推进——适合循环提取,但必须手动重置 lastIndex = 0 才能重复使用同一正则
  • 如果正则含捕获组,match() 在非全局模式下会返回分组内容,exec() 始终返回(即使带 g

常见匹配失败原因:特殊字符没转义、标志用错、贪婪过头

写出来的正则看似正确却匹配不到,大概率卡在这三类问题上。

  • 文本中含 .*?+^$ 等,必须用反斜杠转义,比如匹配字面量 5.99 要写 /5\.99/,写成 /5.99/ 会把 . 当作通配符
  • i 标志处理大小写,m^/$ 匹配行首行尾,s(ES2018+)让 . 匹配换行符——不用 s 时,/.+/ 遇到换行就停住
  • 默认贪婪匹配,/a.*b/"a1b2b" 中会匹配整个 "a1b2b";要最小匹配得写 /a.*?b/

真正难的不是写出能跑的正则,而是写出在边界输入(空字符串、换行符、Unicode 字符、超长文本)下依然稳定、可读、易维护的正则。别为了“一行正则”牺牲可调试性——拆成变量、加注释、用 RegExp 构造函数动态拼接,往往比硬写一个大模式更靠谱。

本篇关于《JavaScript正则表达式使用教程》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>