关于Safari浏览器在ios<16.3版本不支持正则表达式零宽断言的解决办法

异常原因

今天在升级Dify版本的时候发现低版本的ios手机出现了以下报错:

复制代码
SyntaxError: Invalid regular expression: invalid group specifier name

Error: Invalid regular expression: invalid group specifier name
Call Stack
46
eval
[native code] (0:0)
./node_modules/.pnpm/mdast-util-gfm-autolink-literal@2.0.1/node_modules/mdast-util-gfm-autolink-literal/lib/index.js

经过排查发现是Safari浏览器在ios手机低于16.3版本的时候不支持正则表达式的零宽断言。

参考原因:

  1. 相关链接:git issues
    3.相关链接: ios safari 正则兼容问题

解决方式

排查我的异常报错日志,是引用的一个包mdast-util-gfm-autolink-literal/造成的

复制代码
./node_modules/.pnpm/mdast-util-gfm-autolink-literal@2.0.1/node_modules/mdast-util-gfm-autolink-literal/lib/index.js

去git找相关的issues发现有人反馈过:

地址:iOS 和 Safari 版本 <16.4 中新的"负向后视"正则表达式中断

但是官方在此版本并不打算兼容低版本的标准,给出的建议也是使用Babel转译

所以到此有2个解决方案。

方案一:Babel转译配置

1. Babel转译配置

添加Babel插件以转换命名捕获组:

复制代码
npm install --save-dev @babel/plugin-transform-named-capturing-groups-regex

在babel.config.js中:

复制代码
module.exports = {
  plugins: ['@babel/plugin-transform-named-capturing-groups-regex']
};
2. 强制转译node_modules中的依赖

修改构建配置,确保相关依赖被Babel处理:

复制代码
// webpack.config.js 或类似配置
module.exports = {
  module: {
    rules: [
      {
        test: /\.js$/,
        include: /node_modules\/mdast-util-gfm-autolink-literal/,
        use: {
          loader: 'babel-loader',
          options: {
            plugins: ['@babel/plugin-transform-named-capturing-groups-regex']
          }
        }
      }
    ]
  }
};

重新编译

方案二:降级

mdast-util-gfm-autolink-literal在2.0.0的时候没有这个问题,如果可以选择降级的可以指定2.0.0版本

执行降级命令

复制代码
pnpm install mdast-util-gfm-autolink-literal@2.0.0

重新启动验证。

我使用降级后就不再报错了。

相关推荐
00后程序员张1 小时前
iOS混淆与IPA文件加固全流程实战 防止苹果应用被反编译的工程级方案
android·ios·小程序·https·uni-app·iphone·webview
胖虎11 小时前
iOS 推送证书 P8 介绍及生成流程
ios·个推·p8证书·极光推送·ios推送
白熊1882 小时前
【图像大模型】ms-swift 深度解析:一站式多模态大模型微调与部署框架的全流程使用指南
开发语言·ios·swift
2501_915106322 小时前
iOS 应用加固与苹果软件混淆指南,如何防止 IPA 被反编译与二次打包?
android·ios·小程序·https·uni-app·iphone·webview
用户34747547833282 小时前
把SwiftUI View 转为图片
ios·swiftui
mit6.8245 小时前
[FSCalendar] 可定制的iOS日历组件 | docs | Interface Builder
ios
2501_915921435 小时前
iOS 应用加固与苹果软件混淆全解析 IPA 文件防反编译、混淆加密与无源码加固策略
android·macos·ios·小程序·uni-app·cocoa·iphone
2501_929382657 小时前
王国保卫战全集下载 1~5部全系列MOD DLC修版 安卓+ios+PC电脑版
游戏·ios·智能手机·iphone·玩游戏·单机游戏·安卓游戏
2501_916007478 小时前
iOS 代上架实战指南,从账号管理到使用 开心上架 上传IPA的完整流程
android·macos·ios·小程序·uni-app·cocoa·iphone
2501_915918419 小时前
iOS混淆与IPA文件加固深度解析,从反编译风险到苹果应用安全工程实践
android·macos·ios·小程序·uni-app·cocoa·iphone