当前位置: 首页 > ops >正文

【前端】JS引擎 v.s. 正则表达式引擎

  • JS引擎 v.s. 正则表达式引擎
    它们的转义符都是\
    经过JS引擎会进行一次转义
    经过正则表达式会进行一次转义
  • 在一次转义中\\\\\的转义过程:
    第一个 \ (转义符) 会“吃掉”第二个 \,结果是得到一个字面量的 \。
    第三个 \ (转义符) 会“吃掉”第四个 \,结果是得到另一个字面量的 \。
    第五个剩下
    最终结果: 字符串中会包含3个字面量的反斜杠。
  • \d{4}*这种表达是错误的,因为*表示d{4}重复0~N次,前面必须放一个表示新字符的表达式。如.
  • 练习
    这个dataPattern能匹配什么内容?
const str=`
<script>
(function(){
const Patternstr ="\/\\\\\d{4}\/\\\\\d{2}\/\\\\\d{2}\/\.*"; 
const dataPattern = new RegExp(Patternstr);
})()
</script>`
// 把目录div插入到</body>标签前面
html = html.replace(/<\/body>/, str + '</body>');

解析:

  1. 模板字串 (backtick ``)中\也是转义符,Patternstr变为/\\\d{4}/\\\d{2}/\\\d{2}/.*";
  2. 经过 JavaScript 字串解析器处理,Patternstr变为/\\d{4}/\\d{2}/\\d{2}/.*
  3. 经过正则表达式引擎解析,Patternstr变为/\d{4}/\d{2}/\d{2}/.*
  4. 根据正则表达式,可知形如/2025/05/28/.....这类字符串可以被成功匹配
  • 补充
    在 JavaScript 中,.test() 和 .match() 都是 RegExp (正则表达式) 对象或字符串对象的方法,用于执行正则表达式匹配操作。它们的主要区别在于返回值的类型和目的。
    当你只需要判断字符串中是否存在某个模式时,使用 .test()。 它的性能通常比 .match() 更好,因为它一旦找到匹配就会立即返回 true,不需要构建并返回完整的匹配数组。
    当你需要获取匹配到的具体内容、匹配位置或所有匹配项时,使用 .match()。
http://www.xdnf.cn/news/9469.html

相关文章:

  • 创建型设计模式之Singleton(单例)设计模式
  • 力扣热题100(附刷题表版)
  • 【西方哲学-0】西哲思维导图mermaid格式
  • 离线场景下扫描与修复系统缺失补丁解决方案
  • 【计算机网络】第1章:概述—协议层次及服务模型
  • 网络安全之XSS漏洞
  • Unity屏幕适配——适配信息计算和安全区域适配
  • 触控精灵 ADB运行模式填写电脑端IP教程
  • 九、【前后端联调篇】Vue3 + Axios 异步通信实战
  • ​​知识图谱:重构认知的智能革命​
  • 安世亚太:信息化和数字化的底层逻辑
  • Ansible模块——Ansible配置文件!
  • 3D建模的全景图谱:从55个工具到元宇宙的数字革命
  • C++中,`friend`关键字的使用
  • 【数据分析】Matplotlib+Pandas+Seaborn绘图
  • 玻纤效应的时序偏差
  • 大模型本地部署
  • 内网穿透,代理服务,NAT
  • HTTP Accept简介
  • 鸿蒙---使用真机模拟器的时候,图片不加载问题
  • NV295NV306美光固态闪存NV313NW830
  • 决胜2025:企业级BI产品深度评测与选型指南
  • vue+elementUi+axios实现分页(MyBatis、Servlet)
  • Linux进程调度的理解
  • Web攻防-SQL注入增删改查HTTP头UAXFFRefererCookie无回显报错
  • Redis集群热点Key问题解决方案
  • 通过mailto:实现web/html邮件模板唤起新建邮件并填写内容
  • LabVIEW双光子荧光成像软件开发
  • 关于余数的定理
  • 【计算机网络】第1章:概述—分组延时、丢失和吞吐量