【Webpack】HMR 热更新

HMR全称Hot Module Replacement,可以理解为模块热替换,指在应用程序运行过程中,替换、添加、删除模块,而无需重新刷新整个应用。

不使用热更新,我们在应用运行过程中修改了某个模块,通过自动刷新会导致整个应用的整体刷新,那页面中的状态信息都会;如果使用的是HMR,就可以实现只将修改的模块实时替换至应用中,只会重新编译修改的代码,将新的模块发送到客户端,替换掉旧的模块,不必完全刷新整个应用。

实现 HMR 的关键是在客户端和服务器端之间建⽴⼀个 WebSocket 连接,当代码发⽣变化

时,服务器端会将新的模块发送给客户端,客户端接收到新的模块后会⽤新模块替换旧模块,从⽽实现实时更新。

js 复制代码
 const webpack = require('webpack')
 module.exports = {
	 // ...
	 devServer: {
		 //  HMR 
		hot: true
		 // hotOnly: true
	 }
 }

具体来说,webpack HMR 主要分为以下⼏个步骤:

  1. webpack-dev-server 将打包输出 bundle 。
  2. 每当文件发生变更时,webpack 将会重新编译,webpack-dev-server 将会监控到此时文件变更事件,并找到其对应的 module。
  3. webpack-dev-server 将会把变更模块通知到浏览器端,此时使用 websocket 与浏览器进行交流。
  4. 浏览器根据 websocket 接收到 hash,并通过 hash 以 JSONP 的方式请求更新模块的 chunk。
  5. 浏览器加载 chunk,并使用新的模块对旧模块进行热替换,并删除其缓存。
相关推荐
啦啦91188627 分钟前
【版本更新】Edge 浏览器 v142.0.3595.94 绿色增强版+官方安装包
前端·edge
蚂蚁集团数据体验技术1 小时前
一个可以补充 Mermaid 的可视化组件库 Infographic
前端·javascript·llm
LQW_home1 小时前
前端展示 接受springboot Flux数据demo
前端·css·css3
q***d1731 小时前
前端增强现实案例
前端·ar
IT_陈寒1 小时前
Vite 3.0 重磅升级:5个你必须掌握的优化技巧和实战应用
前端·人工智能·后端
JarvanMo1 小时前
Flutter 3.38 + Firebase:2025 年开发者必看的新变化
前端
Lethehong1 小时前
简历优化大师:基于React与AI技术的智能简历优化系统开发实践
前端·人工智能·react.js·kimi k2·蓝耘元生代·蓝耘maas
华仔啊1 小时前
还在用 WebSocket 做实时通信?SSE 可能更简单
前端·javascript
鹏北海2 小时前
多标签页登录状态同步:一个简单而有效的解决方案
前端·面试·架构
_AaronWong2 小时前
基于 Vue 3 的屏幕音频捕获实现:从原理到实践
前端·vue.js·音视频开发