webpack未转译第三方依赖axios为es5导致低端机型功能异常

背景:

兼容性测试流程中,遇到华为p9手机上的页面按钮点击无反应的问题。开发者工具查看后发现报错如下:

根据报错信息检查了一下页面引用的vendors包,发现有...语法,来自于第三方依赖axios。

原因:

axios包有es6语法,而我的项目的webpack.config.js配置的babel-loader排除了所有的node_modules的编译。如下:

javascript 复制代码
{
        test: /\.js$/,
        exclude: /node_modules/,
        use: {
          loader: 'babel-loader'
        },
      },

这样就不会编译axios为es5。

解决方案:

babel-loader也需要编译axios,配置如下:

javascript 复制代码
{
        test: /\.js$/,
        exclude: /node_modules\/(?!(axios)\/).*/, // 仅转译axios等必要库
        use: {
          loader: 'babel-loader'
        },
      },

重新打包后,发现axios已被编译为es5,页面按钮点击正常,bug修复。

优化:

为了防止这个问题的再次发生,在webpack打包后加了一次是否是es5代码的检查,利用webpack-shell-plugin和es-check。

  • webpack-shell-plugin 是一个 Webpack 插件,它允许你在 Webpack 构建过程的不同阶段执行 shell 命令。
  • es-check 是一个用于检查 JavaScript 代码是否符合指定 ECMAScript (ES) 版本规范的工具,可以帮助你在构建流程中确保代码兼容性。
ini 复制代码
// webpack.config.js
const WebpackShellPlugin = require('webpack-shell-plugin');
module.exports = {
	plugins: [
    new WebpackShellPlugin({onBuildEnd:['npm run check-es5']})
  ],
}
json 复制代码
// package.json
  "scripts": {
	"check-es5": "es-check es5 './output/*.js'"
}

这样会在webpack打包之后,对打包的js文件做一次检查。

相关推荐
灵感__idea6 小时前
Hello 算法:贪心的世界
前端·javascript·算法
GreenTea8 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
killerbasd9 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
吴声子夜歌9 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈10 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫10 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝10 小时前
svg图片
前端·css·学习·html·css3
王夏奇10 小时前
python中的__all__ 具体用法
java·前端·python
大家的林语冰11 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
jiayong2311 小时前
第 8 课:开始引入组合式函数
前端·javascript·学习