今天遇到一个问题,农行app嵌套我们的网页,有部分用户手机白屏,浏览版本是 Chrome/69.0.3497.1
页面还有如下的报错:
Uncaught SyntaxError: Unexpected token .
/marketing/js/chunk.359.1768370456951.js
SyntaxError: Unexpected token .
这个报错是Vue 项目编译 / 打包后运行时的语法解析错误,核心特征:浏览器无法识别代码中的某个 . 点语法,报错定位在打包后的 chunk 分包文件(chunk.359.1768370456951.js)里,属于非常典型的 Vue 项目部署 / 打包类语法兼容问题
这个报错的本质是:你的 Vue 项目中写了【ES6 + 的新语法 / 对象语法】,但打包时没有被babel完全转译兼容,浏览器无法识别该语法,导致解析中断并抛出【意外的符号 .】错误
解决方案:
// 原代码(报错语法)
const name = user?.name;
// 替换后(ES5兼容写法)
const name = user && user.name;
也可以使用解析 ES2020 语法的 babel 插件 (但是我没试过)
npm install @babel/plugin-proposal-optional-chaining @babel/plugin-proposal-nullish-coalescing-operator --save-dev