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文件做一次检查。

相关推荐
码农秋27 分钟前
Element Plus DatePicker 日期少一天问题:时区解析陷阱与解决方案
前端·vue.js·elementui·dayjs
未来之窗软件服务30 分钟前
未来之窗昭和仙君(五十六)页面_预览模式——东方仙盟筑基期
前端·仙盟创梦ide·东方仙盟·昭和仙君·东方仙盟架构
top_designer32 分钟前
Illustrato:钢笔工具“退休”了?Text to Vector 零基础矢量生成流
前端·ui·aigc·交互·ux·设计师·平面设计
星哥说事37 分钟前
星哥带你玩飞牛NAS-13:自动追番、订阅下载 + 刮削,动漫党彻底解放双手!
前端
donecoding1 小时前
前端AI开发:为什么选择SSE,它与分块传输编码有何不同?axios能处理SSE吗?
前端·人工智能
安_1 小时前
<style scoped>跟<style>有什么区别
前端·vue
姝然_95271 小时前
Claude Code 命令完整文档
前端
wjcroom1 小时前
web版进销存的设计到实现一
前端
无知的前端1 小时前
Flutter常见问题以及解决方案
前端·flutter·dart
BD_Marathon1 小时前
Vue3_Vite构建工程化前端项目
前端