登录
首页 >  文章 >  前端

JavaScript正则表达式使用教程

时间:2025-12-14 18:39:35 294浏览 收藏

推广推荐
免费电影APP ➜
支持 PC / 移动端,安全直达

最近发现不少小伙伴都对文章很感兴趣,所以今天继续给大家介绍文章相关的知识,本文《JavaScript正则表达式怎么用?文本匹配全解析》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~

JavaScript正则表达式是匹配、查找、替换文本模式的工具,支持字面量(/abc/)和构造函数(new RegExp("abc"))两种创建方式,提供match、test、replace、split等方法及g/i/m修饰符和\d、\w、.等元字符。

javascript中的正则表达式是什么_如何匹配文本?

JavaScript 中的正则表达式(Regular Expression,简称 RegExp)是一种用于匹配、查找、替换文本中特定模式的工具。它用一套简洁但功能强大的语法规则来描述字符串的结构,比如“以字母开头、后面跟 3 到 5 位数字”或“看起来像邮箱的格式”。

正则表达式的两种写法

你可以用字面量或构造函数创建正则对象:

  • 字面量写法:/abc/ —— 简洁,适合静态模式
  • 构造函数写法:new RegExp("abc") —— 动态生成时更灵活,比如拼接变量

注意:构造函数中传入字符串时,反斜杠要双写(如 \\d),因为字符串本身会先解析一次转义。

常用匹配方法

JS 提供多个内置方法操作正则:

  • str.match(/pattern/):返回匹配结果数组(含捕获组),没匹配到返回 null
  • str.test(/pattern/):只返回 true 或 false,适合条件判断
  • str.replace(/pattern/, "new"):替换匹配内容,支持全局 flag 和函数回调
  • str.split(/pattern/):按匹配结果切分字符串

例如:"hello123world".match(/\d+/) 返回 ["123"]/\d+/.test("abc") 返回 false

关键修饰符(flags)和基础元字符

修饰符写在正则末尾,改变匹配行为:

  • g(global):全局匹配,不加默认只找第一个
  • i(ignoreCase):忽略大小写,如 /a/i 匹配 "A" 或 "a"
  • m(multiline):让 ^ 和 $ 匹配每行起止,不只是整个字符串首尾

常见元字符示例:

  • \d 匹配数字,\w 匹配字母/数字/下划线
  • . 匹配任意单个字符(换行符除外),^ 行首,$ 行尾
  • [abc] 匹配 a、b 或 c;[^0-9] 匹配非数字
  • +(1 次以上)、*(0 次以上)、?(0 或 1 次)、{3,5}(3 到 5 次)

实际小例子:验证手机号(简化版)

假设中国手机号是 11 位,以 1 开头,第二位是 3–9:

const phoneReg = /^1[3-9]\d{9}$/;
console.log(phoneReg.test("13812345678")); // true
console.log(phoneReg.test("12812345678")); // false(第二位不是 3–9)

这里 ^$ 确保整串都符合,避免部分匹配;[3-9] 限定第二位范围;\d{9} 补齐剩下 9 位数字。

基本上就这些。正则不复杂但容易忽略细节,多练几个常见场景(邮箱、日期、URL、空格处理)就顺手了。

理论要掌握,实操不能落!以上关于《JavaScript正则表达式使用教程》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>