登录
首页 >  文章 >  前端

JavaScript正则表达式使用教程

时间:2026-04-24 11:06:35 421浏览 收藏

JavaScript正则表达式的核心在于精准选用test()判断匹配存在性、match()或exec()提取内容,而非盲目套用复杂模式;文章强调优先用includes()/indexOf()处理简单查找,并深入剖析了转义特殊字符、标志(i/m/s)的正确使用、贪婪与非贪婪控制等高频踩坑点,同时提醒开发者关注边界场景下的稳定性、可读性与可维护性——真正考验功力的,不是写出能跑的正则,而是写出在空字符串、换行符、Unicode和超长文本下依然稳健可靠的正则。

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学习网公众号也会发布文章相关知识,快来关注吧!

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