登录
首页 >  文章 >  前端

正则表达式是什么?JS如何匹配字符串

时间:2026-02-19 19:54:41 465浏览 收藏

正则表达式是JavaScript中强大而灵活的字符串处理工具,它通过简洁的模式语法(如/\d+/、/\b\w+@\w+\.\w+\b/g)实现精准匹配、提取、替换与分割,支持字面量和RegExp构造函数两种创建方式,并深度集成于test()、match()、replace()、split()等核心字符串方法中;掌握基础元字符(\d、\w、\s、^、$、\b)和常用标志(g/i/m)就能高效应对邮箱验证、手机号提取、日志解析等真实开发场景——看似神秘,实则入门简单、实用性强,是每个前端开发者值得熟练掌握的文本处理利器。

什么是正则表达式_javascript中如何匹配字符串?

正则表达式(Regular Expression,简称 regex 或 regexp)是一种用于匹配、查找、替换字符串中特定模式的语法工具。在 JavaScript 中,它通过内置的 RegExp 对象或字面量形式(如 /abc/)创建,配合字符串方法(如 test()match()replace() 等)实现高效文本处理。

JavaScript 中如何创建正则表达式

有两种方式:

  • 字面量写法:直接用斜杠包裹模式,例如 /\d+/ 匹配一个或多个数字;支持可选标志(如 /abc/gi 表示全局+忽略大小写)。
  • 构造函数写法new RegExp('\\d+', 'g');注意字符串中反斜杠要双写(因为字符串本身会转义一次)。

常用匹配方法及用途

字符串对象提供多个正则相关方法:

  • str.test(/pattern/):返回布尔值,判断是否匹配,常用于表单验证(如邮箱格式检查)。
  • str.match(/pattern/g):返回匹配结果数组,加 g 标志可获取全部匹配项;不加则只返回第一个及捕获组信息。
  • str.replace(/pattern/, 'newStr'):替换匹配内容,支持函数作为第二个参数做动态替换。
  • str.split(/pattern/):按正则切分字符串,比固定字符更灵活(如用 /\\s+/ 按任意空白分割)。

基础但实用的元字符和标志

掌握几个关键符号就能解决大部分需求:

  • \d 匹配数字,\w 匹配字母/数字/下划线,\s 匹配空白;对应大写为“非”(如 \D 非数字)。
  • ^ 表示开头,$ 表示结尾,\b 表示单词边界(如 /\bcat\b/ 不会匹配 category)。
  • 常用标志:g(全局)、i(忽略大小写)、m(多行模式,让 ^$ 匹配每行起止)。

一个小例子:提取所有邮箱

假设有一段文本:"联系我:a@b.com 或 admin@test.org",想取出所有邮箱:

const text = "联系我:a@b.com 或 admin@test.org";
const emailRegex = /\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Z|a-z]{2,}\b/g;
console.log(text.match(emailRegex)); // ["a@b.com", "admin@test.org"]

这个模式虽不覆盖所有 RFC 标准邮箱,但对日常场景已足够可靠。

基本上就这些。正则表达式不复杂但容易忽略细节,比如忘记转义点号 . 或混淆 *+ 的含义。多练几个常见场景(手机号、日期、URL),很快就能上手。

今天关于《正则表达式是什么?JS如何匹配字符串》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

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