news 2026/4/4 23:18:46

JS正则表达式实战:核心语法解析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
JS正则表达式实战:核心语法解析
JS中的正则表达式实例集锦:
部分语法类型核心含义
/.../定界符正则表达式的边界标识(JavaScript/Perl 等语言的标准写法),包裹正则主体。
\.转义字符匹配字面量的点号.。⚠️ 重点:正则中.是通配符(匹配任意单个字符),必须用\转义才能匹配实际的.
()分组符正则的 “分组” 语法,作用是:1. 把括号内的内容视为一个整体;2. 捕获匹配到的内容(可通过 $1/$2 等引用);⚠️ 这里括号内是空的,意味着 “匹配空内容”。
$锚点匹配字符串的结束位置,确保$前面的内容必须出现在字符串最后。
匹配 / 不匹配示例

javascript

// 示例1:匹配 .txt 结尾的文件(把空分组换成 txt) const reg1 = /\.(txt)$/; console.log(reg1.test("note.txt")); // true console.log(reg1.test("note.txt.bak")); // false(结尾不是 .txt) // 示例2:匹配 .json 或 .yml 结尾的文件(分组内加或逻辑) const reg2 = /\.(json|yml)$/; console.log(reg2.test("config.json")); // true console.log(reg2.test("docker.yml")); // true console.log(reg2.test("data.csv")); // false

?正则表达式

用法 1:匹配「前面的字符 / 分组」0 次或 1 次(最基础)

这是你之前在woff2?中看到的用法,也是最常用的。

  • 语法字符?(分组)?
  • 含义:表示它前面紧邻的那个字符 / 分组是「可选的」—— 匹配 0 次(没有)或 1 次(有)。
  • 示例
  • const reg = /^86?1[3-9]\d{9}$/; // 不带区号的 11 位手机号(正常场景) console.log(reg.test('13800138000')); // false console.log(reg.test('19912345678')); // false // 带 86 区号的手机号 console.log(reg.test('8613800138000')); // true console.log(reg.test('8617788990011')); // true // 示例1:匹配 color 或 colour(英式拼写) const reg1 = /colou?r/; console.log(reg1.test('color')); // true(u 出现 0 次) console.log(reg1.test('colour')); // true(u 出现 1 次) console.log('colouur is :',reg1.test('colouur'));// false(u 出现 2 次) // 示例2:匹配手机号(可选带区号 86) const reg2 = /^86?1[3-9]\d{9}$/; console.log('13800138000 is :',reg2.test('13800138000')); // false(86 出现 0 次) console.log(reg2.test('8613800138000')); // true(86 出现 1 次) console.log(reg2.test('88613800138000'));// false(86 多了个 8)

    用法 2:将「贪婪匹配」转为「非贪婪匹配」(重要)

    正则默认是「贪婪模式」(尽可能多匹配),?加在*/+/?/{n,m}后,会变成「非贪婪模式」(尽可能少匹配)。

  • 语法*?/+?/??/{n,m}?
  • 含义:匹配到满足条件的「最短内容」就停止。
  • 示例

    javascript

    const str = '<div>内容1</div><div>内容2</div>'; // 贪婪匹配(默认):匹配从第一个 <div> 到最后一个 </div> 的所有内容 const regGreedy = /<div>.*<\/div>/; console.log(str.match(regGreedy)[0]); // 输出:<div>内容1</div><div>内容2</div> // 非贪婪匹配(加?):匹配第一个 <div> 到最近的 </div> const regNonGreedy = /<div>.*?<\/div>/; console.log(str.match(regNonGreedy)[0]); // 输出:<div>内容1</div>

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/31 22:43:33

吐血推荐专科生必用的9款AI论文工具

吐血推荐专科生必用的9款AI论文工具 2026年专科生论文写作工具测评&#xff1a;为何需要一份精准榜单 随着AI技术的不断成熟&#xff0c;越来越多的专科生开始借助AI工具提升论文写作效率。然而&#xff0c;面对市场上五花八门的论文辅助软件&#xff0c;如何选择真正适合自己…

作者头像 李华
网站建设 2026/3/30 2:19:44

最近邻算法 (kNN) 通俗讲解

最近邻算法&#xff0c;全称 k-Nearest Neighbors (kNN)&#xff0c;是一种简单却强大的机器学习算法。它属于“监督学习”的一种&#xff0c;主要用于分类&#xff08;比如判断一个东西属于哪个类别&#xff09;和回归&#xff08;预测一个数值&#xff09;。通俗点说&#xf…

作者头像 李华
网站建设 2026/4/4 11:52:14

如何利用云服务器搭建游戏服务器并实现跨平台游戏?

云服务器搭建游戏服务器并实现跨平台游戏完整指南一、云服务器选择与配置1. 服务器选型建议根据游戏类型和玩家规模选择合适的配置&#xff1a;休闲游戏/小型服务器&#xff1a;2核CPU/4GB内存/50GB SSD&#xff0c;支持10-20人同时在线中型游戏/竞技游戏&#xff1a;4核CPU/8G…

作者头像 李华
网站建设 2026/4/3 3:57:56

CMake:现代C/C++项目的构建中枢

CMake&#xff1a;现代C/C项目的构建中枢 引言&#xff1a;从构建混乱到标准化 想象你正在开发一个跨平台的C库&#xff0c;需要在Windows、Linux、macOS上都能构建。在CMake出现之前&#xff0c;这意味着&#xff1a;为Visual Studio编写.vcxproj文件为Linux编写复杂的Mak…

作者头像 李华
网站建设 2026/3/26 14:49:27

Paperxie 毕业论文:从选题到定稿的一站式智能写作解决方案

paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/aippt https://www.paperxie.cn/ai/dissertationhttps://www.paperxie.cn/ai/dissertation 对于每一位高校毕业生而言&#xff0c;毕业论文不仅是学业生涯的收官之作&#xff0c;更是学术能力的集中考验。…

作者头像 李华
网站建设 2026/4/2 10:25:42

【无人机追踪】基于资源福利任务分配算法的无人机集群任务分配算法,完成目标攻击任务的基础上,通过优化资源分配和能耗控制附Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。&#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室&#x1f447; 关注我领取海量matlab电子书和数学建模资料 &#x1f34…

作者头像 李华