背景介绍

先说一下这一次出现问题的需求背景,在顺便引出 html-webpack-plugin。最近在做监控,而我需要监控到文件加载错误,并实现上报。熟悉的小伙伴,已经知道,这是一个很容易实现的功能

 <script>window.addEventListener('error', function(event) {console.log(event)},true)</script><script src="cutex/xuan.js"></script>

当我们加载 cutex/xuan.js 这个文件的时候,加载失败,报告404错误。这个时候,我们就可以在 addEventListener 中监听到这个错误,并实现上报。

这个demo,我已经跑通了,但是我在本地搭建webpack环境,并将代码扔到封装好的监控文件中,却这么也不行…

详情描述

正常逻辑下,我封装了监控文件 monitor ,项目结构如下:

同时呢,我在webpack的配置如下:

const path = require('path')
const HtmlWebpackPlugin = require('html-webpack-plugin')
module.exports = {entry: "./src/index.js",mode: "development",output: {path: path.resolve(__dirname,"dist"),filename: "monitor.js"},devServer: {contentBase: path.resolve(__dirname,'dist')},plugins: [new HtmlWebpackPlugin({template: "./src/index.html",inject: 'head'})]
}

正常逻辑,我的entry入口,指向了引入 monitor 的js,同时,我们引入html-webpack-plugin 以 index.html 为模版打包,同时也指向了入口文件的打包位置 inject: ‘head’。

解决过程

周五下午发现的这个问题,一直没有解决。想着是周五,也就没有太用心解决他。晚上睡觉前,想着看个电影睡觉,但是突然想起来这个事情。于是乎,起床,拿电脑,开机,完美解决,同时大半夜写了个周报。

1、本地的demo可以跑通,但是扔到webpack中,却出现了问题。那么就是这个webpack配置有问题。
2、在webpack中,不将代码写到 monitor 文件中,就可以执行。那就是monitor的问题?但是其他错误监控却没有。
3、资源加载错误与其他错误监控有个区别,他的加载必须先于资源加载,否则,根本无法触发错误。可是我们前面已经配置了这个,将代码放到了html的最上面。

inject: 'head'

4、实践是检验真理的唯一标准。npm run build,看看到底是怎么一回事。位置没有问题,代码也没有问题。但是…

<script defer src="monitor.js"></script>

为什么,会多一个defer属性呢?

我们都知道,加了该属性的script,脚本会在文档渲染完毕后,DOMContentLoaded事件调用前执行。

那么,罪魁祸首就是他,在打包好的dist中,我去掉了defer,一切都好了。

5、定位问题了,接下来就要知道是哪部分出了问题。因为我使用了webpack5,第一怀疑就是他,转而想想又不是(确实不是,后续我还专门降级到webpack4测试)。打包他的是html-webpack-plugin 。
6、我先去了webpack找html-webpack-plugin的文档,没有找到原因。接着又去找github的 html-webpack-plugin ,这一次找到原因…


图中标黄的,是他的默认值,所以会自动加defer属性,
按照文档,修改如下:

plugins: [new HtmlWebpackPlugin({template: "./src/index.html",inject: 'head',scriptLoading: 'blocking'})]

版本

我记得之前使用 html-webpack-plugin 打包是不会添加 defer的。为了验证自己的记忆,我又查看了版本…

当前项目我使用的是 5.2.0, 2月份更新的

最新的版本是 5.3.1 18天前更新的

本地有使用记录的是4.5.1 一月份更新,这个版本的就不会自动添加defer属性

总结

通过这个事情,其实可以得出很多结论。遇到问题不要慌,也不要忙着问人。因为像这种问题,百度都不知道如何百度(百度的前提是定位了方向)。

自己多思考,而且像这种莫名其妙的问题,大多少情况,大概率是版本问题。

本次分享就到这里,感觉我还不错的伙伴,点个赞,加个关注呗!!!小轩,先行拜谢。

html-webpack-plugin 又出幺蛾子 | 一次解决bug的过程相关推荐

  1. 【软件测试】测试人我明明测了,生产环境还出问题?又出幺蛾子......

    目录:导读 前言 一.Python编程入门到精通 二.接口自动化项目实战 三.Web自动化项目实战 四.App自动化项目实战 五.一线大厂简历 六.测试开发DevOps体系 七.常用自动化测试工具 八 ...

  2. win10当生产服务器稳定吗,真让人不省心!Win10最稳定版出幺蛾子 微软已证实

    作为Windows 10系统目前最稳定的两个版本,Version 1903/1909更新后也出现了幺蛾子,微软已经证实了. 微软悄然更新了 Windows 10 Version 1903/1909 功 ...

  3. MySQL主从复制以及会出现的幺蛾子问题、解决方法

    目录 引言 一.主从复制原理 1.1.MySQL支持的复制类型 基于语句的复制(STATEMENT) 基于行的复制(ROW) 混合类型的复制(MIXED) 1.2.主从复制的工作过程 1.3.mysq ...

  4. 百度云盘幺蛾子多,我们不用他难道还不行了吗?

    前言 前阵子百度云又出了不少幺蛾子. 先是把 Pandownload(百度云破解器)作者逮进去了: 后是薅用户羊毛,强行占带宽: 百度云盘幺蛾子多,我们不用他难道还不行了吗? 所以今天特意写篇推送告诉 ...

  5. 升级iOS11.2的同学注意了! 刚拯救iPhone无限重启, iPhoneX又出新幺蛾子

    就在昨日许多iPhone用户在更新到iOS11.1.2的系统后,手机多次出现黑屏重启,小编在打电话时也遇到重启的情况.许多网友们也反映在正常使用手机时就开始出现黑屏转动"小菊花". ...

  6. Webpack之插件html webpack plugin

    Webpack之插件html webpack plugin html-webpack-plugin插件 动态生成html文件并自动引入js文件 静态文件无需加载js或css文件,通过设置入口文件可以将 ...

  7. php永久mediaid,幺蛾子事件之-zabbix配置告警媒介报错mediaid重复

    幺蛾子事件之-zabbix配置告警媒介报错mediaid重复 admin • 2020 年 12 月 21 日 直接开篇点题好吧zabbix运行一段时间后,添加报警媒介类型后,添加收件人信息后保存报错 ...

  8. SAP WM 上架策略R的几个幺蛾子

    SAP WM 上架策略R的几个幺蛾子 SAP WM模块中的上架策略R(Dynamic coordinate reference number),项目实践中很少使用.这引起了笔者的好奇,是故打算花点时间 ...

  9. Python_内置函数之round的幺蛾子

    pycharm运行结果 1 ret = round(0.5) 2 print(ret) >>> 0 3 4 ret1 = round(1.5) 5 print(ret1) >& ...

最新文章

  1. Linux下实现apache代理tomcat
  2. javascript --- 再识闭包
  3. [原创]FineUI秘密花园(二十七) — 窗体控件概述(上)
  4. new 结构体指针_Go:我应该用指针替代结构体的副本吗?
  5. 马斯克又吊大家胃口:9月22日电池日有众多亮点揭晓
  6. pyspark的ALS协同过滤推荐算法-小结1
  7. 网上银行加密通信服务系统解决方案
  8. python3 mysql插入数据冲突
  9. 给html标签加上鼠标划过小手样式
  10. 通过图书编号查询python,基于Python的ISBN书号查询示例代码-六派数据
  11. 统计字符串中字符ch出现的次数c语言,C语言与汇编的嵌入式编程:统计字符串中各字符出现的次数...
  12. linux ps1 配色,bashrc - PS1(提示符配色)
  13. 一起教育科技2020净收1.92亿元 官网却启用杂米域名17zyw.cn
  14. XmlHttp的open( )方法
  15. 洛谷 1462 通往奥格瑞玛的道路 题解
  16. bpmn定义之camunda bpm生命周期
  17. 3D地形编程——之GeoMipMap基础(1)
  18. [转]研究生能力自我培养手册
  19. SecureCRT乱码解决
  20. Shell脚本运行中的停止方法

热门文章

  1. windows系统下,如何使用win+R快速打开安装的应用
  2. 使用Netty实现一个小型服务器(作为数据中转站)
  3. C++编程练习 - 关羽过关斩将
  4. 逻辑运算符符号化命题——数理逻辑
  5. 弹幕调试 jquery.danmu.js
  6. 示波器探头上的×10
  7. PX4模块设计之二十六:BatteryStatus模块
  8. 8.中学班级管理与教师心理
  9. 计算机跨考地信研究生,过来人解答关于跨考地信后续的几个复习问题
  10. 【Python中字典的len()方法】