webpack配置hot是否需要配置HotModuleReplacementPlugin

webpack配置hot是否需要配置HotModuleReplacementPlugin

webpack官方文档(devserverhot)中介绍,使用hmr的时候,需要满足两个条件:

  1. 配置devServer.hot为true
  2. 配置webpack.HotModuleReplacementPlugin插件

Note that webpack.HotModuleReplacementPlugin is required to fully enable HMR. If webpack or webpack-dev-server are launched with the --hot option, this plugin will be added automatically, so you may not need to add this to your webpack.config.js*.

请注意:webpack要完全启用HMR需要使用webpack.HotModuleReplacementPlugin。如果webpack或webpack-dev-server 通过命令行添加 --hot 选项启动,这个插件会自动添加,所以您不需要将它添加到webpack.config.js中

但是,经实际使用 webpack-dev-server 时发现,在webpack.config.js中仅仅配置了devServer.hot:true,而未添加这个插件的状态下,仍然实现了HMR。

原来 webpack-dev-server 内部自动帮我们完成了这个事情。

通过在Github 的 webpack-dev-server 搜索,找到以下代码(源码地址):

if (options.hot || options.hotOnly) {
  config.plugins = config.plugins || [];
  if (
    !config.plugins.find(
      // Check for the name rather than the constructor reference in case
      // there are multiple copies of webpack installed
      (plugin) => plugin.constructor.name === 'HotModuleReplacementPlugin'
    )
  ) {
    config.plugins.push(new webpack.HotModuleReplacementPlugin());
  }
}

代码判断了配置的插件中是否包含名为HotModuleReplacementPlugin的插件,如果没有则添加。

再查看搜索结果中的Commits:fix: check for name of HotModuleReplacementPlugin to avoid RangeError #2146

这段代码还被调整过,调整前判断的依据是constructor,调整后用name判断。

至此,我们确定,webpack-dev-sever内部对HotModuleReplacementPlugin插件做了判断,当配置了devServer.hot:true时,就自动添加这个插件。

但是webpack源码中未搜到类似操作,所以使用其他工具启用服务器并开启HMR时,应该仍需手动添加这个插件。

PS:可能需要你自己尝试验证一下

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值