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

异常原因

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

vbnet 复制代码
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/[email protected]/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/造成的

bash 复制代码
./node_modules/.pnpm/[email protected]/node_modules/mdast-util-gfm-autolink-literal/lib/index.js

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

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

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

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

方案一:Babel转译配置

1. Babel转译配置

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

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

在babel.config.js中:

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

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

javascript 复制代码
// 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版本

执行降级命令

css 复制代码
pnpm install [email protected]

重新启动验证。

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

相关推荐
光影少年14 分钟前
vue中,created和mounted两个钩子之间调用时差值受什么影响
前端·javascript·vue.js
青苔猿猿17 分钟前
node版本.node版本、npm版本和pnpm版本对应
前端·npm·node.js·pnpm
一只码代码的章鱼1 小时前
Spring的 @Validate注解详细分析
前端·spring boot·算法
zimoyin1 小时前
Kotlin 协程实战:实现异步值加载委托,对值进行异步懒初始化
java·前端·kotlin
程序员与背包客_CoderZ3 小时前
Node.js异步编程——Callback回调函数实现
前端·javascript·node.js·web
非凡ghost3 小时前
Pale Moon:速度优化的Firefox定制浏览器
前端·firefox
清灵xmf4 小时前
从 Set、Map 到 WeakSet、WeakMap 的进阶之旅
前端·javascript·set·map·weakset·weakmap
11054654014 小时前
11、参数化三维产品设计组件 - /设计与仿真组件/parametric-3d-product-design
前端·3d
爱笑的林羽4 小时前
Mac M系列 安装 jadx-gui
前端·macos
运维@小兵4 小时前
vue使用路由技术实现登录成功后跳转到首页
前端·javascript·vue.js