webpack 热更新的实现原理

定义

webpack 的热更新⼜称热替换(Hot Module Replacement),缩写为HMR。 这个机制可以做到不⽤刷新浏览器⽽将新变更的模块替换掉旧的模块。

原理

webpack 的热更新在 server 及 client 端都做了处理,我们来了解一下这个过程:

(1)webpack 在 watch 模式下,文件系统中的某一个文件发生修改,webpack 监听到文件变化,根据配置文件对模块进行重新编译打包,并将打包后的代码通过简单的 JavaScript 对象保存在内存中。

(2)webpack-dev-server 与 webpack 之间的接口交互,主要是webpack-dev-middleware 调⽤ webpack暴露的 API 对代码变化进⾏监 控,并且告诉 webpack,将代码打包到内存中。

(3)webpack-dev-server 监控:当我们在配置⽂件中配置了devServer.watchContentBase 为 true 的时候,Server 会监听这些配置⽂件夹中静态⽂件的变化,变化后会通知浏览器端对应⽤进⾏ live reload。

注意,这⼉是浏览器刷新,和 HMR 是两个概念。

(4)主要是通过sockjs(webpack-dev-server 的依赖)在浏览器端和服务端之间建⽴⼀个 websocket ⻓连接,将 webpack 编译打包的各个阶段的状态信息告知浏览器端,同时也包括第三步中 Server 监听静态⽂件变化的信息。浏览器端根据这些 socket 消息进⾏不同的操作。当然服务端传递的最主要信息还是新模块的hash 值,后⾯的步骤根据这⼀hash 值来进⾏模块热替换。

相关推荐

  1. webpack 更新实现原理

    2024-04-04 23:22:03       36 阅读
  2. 【前端工程化面试题目】webpack 更新原理

    2024-04-04 23:22:03       53 阅读
  3. Webpack】HMR 更新

    2024-04-04 23:22:03       20 阅读
  4. webpack原理之-打包流程&更新HMR

    2024-04-04 23:22:03       42 阅读
  5. 前端开发中更新原理

    2024-04-04 23:22:03       32 阅读
  6. vue如何实现Webpack加载

    2024-04-04 23:22:03       32 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-04 23:22:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-04 23:22:03       101 阅读
  3. 在Django里面运行非项目文件

    2024-04-04 23:22:03       82 阅读
  4. Python语言-面向对象

    2024-04-04 23:22:03       91 阅读

热门阅读

  1. 开发人员小张出场

    2024-04-04 23:22:03       34 阅读
  2. DAY01

    2024-04-04 23:22:03       49 阅读
  3. 010 Editor常用语法

    2024-04-04 23:22:03       36 阅读
  4. 线程通信机制

    2024-04-04 23:22:03       41 阅读