登录
首页 >  文章 >  前端

JS正则表达式使用教程:匹配替换全解析

时间:2026-01-21 16:31:39 221浏览 收藏

在IT行业这个发展更新速度很快的行业,只有不停止的学习,才不会被行业所淘汰。如果你是文章学习者,那么本文《JavaScript正则表达式怎么用?字符串匹配替换教程》就很适合你!本篇内容主要包括##content_title##,希望对大家的知识积累有所帮助,助力实战开发!

JavaScript正则表达式是用于匹配、查找、提取或替换字符串模式的工具,支持字面量(如/abc/)和RegExp构造函数创建,配合test()、match()、replace()等方法使用。

javascript正则表达式是什么_如何用它进行字符串匹配和替换?

JavaScript 正则表达式(Regular Expression,简称 RegExp)是一种用于匹配、查找、提取或替换字符串中特定模式的语法工具。它不是 JavaScript 独有,但 JS 提供了原生支持,通过 RegExp 构造函数或字面量(如 /abc/)创建,并配合字符串方法(如 test()match()replace()split())高效处理文本。

正则表达式基础写法与常见符号

正则由普通字符(如 a1)和元字符(如 \d+*^$)组成。常用元字符和简写:

  • \d 匹配任意数字(等价于 [0-9]
  • \w 匹配字母、数字、下划线(等价于 [a-zA-Z0-9_]
  • \s 匹配空白符(空格、制表符、换行等)
  • + 表示“前面的元素出现一次或多次”
  • * 表示“前面的元素出现零次或多次”
  • ? 表示“前面的元素出现零次或一次”
  • ^ 匹配字符串开头,$ 匹配字符串结尾
  • \b 匹配单词边界(如 \bcat\b 只匹配独立单词 “cat”,不匹配 “category”)

用 test() 和 match() 进行字符串匹配

test() 返回布尔值,适合做条件判断;match() 返回匹配结果数组(含捕获组),适合提取内容。

例如验证手机号(简单版:11位数字,以1开头):

const phoneReg = /^1\d{10}$/;
console.log(phoneReg.test("13812345678")); // true
console.log(phoneReg.test("1234567890")); // false

再比如提取所有邮箱地址:

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

用 replace() 进行精准替换

replace() 支持字符串或正则作为第一个参数。使用正则时可加标志(flags)控制行为:

  • g(global):全局匹配(否则只替换第一个)
  • i(ignoreCase):忽略大小写
  • m(multiline):让 ^$ 匹配每行起止

示例:将文本中所有连续空格替换成单个空格,并去掉首尾空格:

const str = " hello world ";
const cleaned = str.replace(/\s+/g, " ").trim(); // "hello world"

进阶用法:用捕获组实现格式转换,比如把 "2023-10-05" 转成 "05/10/2023"

const dateStr = "2023-10-05";
const newDate = dateStr.replace(/(\d{4})-(\d{2})-(\d{2})/, "$3/$2/$1"); // "05/10/2023"

注意事项与实用技巧

正则容易写错,调试建议:

  • 在浏览器控制台或在线工具(如 regex101.com)中实时测试,开启“JS 模式”
  • 注意转义:匹配反斜杠本身要写 \\,匹配点号要写 \.
  • 动态生成正则时用 RegExp 构造函数,避免字面量无法拼接变量的问题:new RegExp(`\\b${keyword}\\b`, "gi")
  • 性能敏感场景慎用过于复杂的正则(如嵌套量词),必要时拆解为多个简单操作

以上就是《JS正则表达式使用教程:匹配替换全解析》的详细内容,更多关于的资料请关注golang学习网公众号!

前往漫画官网入口并下载 ➜
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>