0

0

javascript如何实现模块热替换_它的原理是什么

夜晨

夜晨

发布时间:2025-12-16 18:52:03

|

134人浏览过

|

来源于php中文网

原创

HMR是构建工具提供的开发期能力,不刷新页面即可更新模块并保留状态;其依赖服务端监听、客户端WebSocket通信、模块动态替换及框架适配层,原生JS因ESM静态绑定而不支持。

javascript如何实现模块热替换_它的原理是什么

JavaScript 本身不直接支持模块热替换(HMR,Hot Module Replacement),它是构建工具(如 Webpack、Vite)在开发阶段提供的能力,核心目标是:**不刷新页面,只更新被修改的模块及其依赖,保留应用当前状态**。

HMR 是怎么工作的

HMR 的本质是一套运行时通信 + 模块管理机制。它不是语言特性,而是由打包工具注入的客户端逻辑与服务端协调配合完成的:

  • 服务端监听文件变化:当源码(如 .js、.vue 文件)保存时,构建工具重新编译变更模块,生成新的模块代码和一个“更新清单”(包含哪些模块变了、新模块 ID 和 hash)
  • 客户端接收更新通知浏览器里运行的 HMR 运行时(由构建工具自动注入)通过 WebSocket 或 EventSource 与本地开发服务器保持连接,收到更新后拉取新模块代码
  • 按需替换模块:运行时尝试逐级检查模块是否支持 HMR(即是否调用了 module.hot.accept() 或框架(如 React/Vue)的 HMR 插件已注册处理逻辑),对可接受更新的模块,用新代码替换旧模块的 exports,并触发 dispose(清理副作用)和 apply(重置状态)生命周期
  • 状态不丢失的关键在于“不销毁实例”:比如 React 组件更新时,HMR 插件会保留在 DOM 中的组件实例,仅替换其内部 render 方法或 state 初始化逻辑;Vue 单文件组件则会复用现有组件实例,重新挂载新定义

手动启用 HMR(以 Webpack 为例)

你不需要从零写 HMR 运行时,但可以主动控制模块如何响应更新:

  • 在模块顶部检查 module.hot 是否存在(仅开发环境有)
  • 调用 module.hot.accept('./dep.js', callback) 声明:当依赖模块更新时执行回调(例如重新渲染 UI、重置配置)
  • module.hot.dispose(callback) 清理上一次模块中的副作用(如定时器、事件监听器、全局变量)
  • 注意:顶层模块(如入口文件)一般不直接 accept 自身,而是由框架插件接管(如 @pmmmwh/react-refresh-webpack-plugin
示例(简单 JS 模块):
if (module.hot) {
  module.hot.accept('./utils.js', () => {
    console.log('utils 已更新,可重新初始化逻辑');
    // 例如:重新绑定按钮事件、刷新图表数据
  });

  module.hot.dispose(() => {
    console.log('清理旧 utils 副作用');
    // 如 clearTimeout(timerId)
  });
}

为什么原生 JS 不支持?HMR 依赖什么

因为标准 JavaScript 模块(ESM)加载后是静态绑定、不可变的:import 在编译时确定,export 对象不可被外部替换。HMR 能工作,靠的是:

Upscale
Upscale

AI图片放大工具

下载

立即学习Java免费学习笔记(深入)”;

  • 构建工具劫持模块系统:Webpack 把你的 ES 模块包装成函数,用自定义的 __webpack_require__ 控制加载;Vite 则利用浏览器原生 ESM,通过动态 import() 加载新模块 URL,并 patch 模块缓存
  • 运行时模块注册表:每个模块都有唯一 ID,导出对象被统一管理,替换时能定位到对应模块实例
  • 开发者约定或框架适配层:纯 JS 模块默认不支持热更新;只有显式调用 accept 或使用 React Refresh / Vue Loader 等插件,才具备“安全更新”的能力

实际开发中你该怎么做

  • 用 Vite 或 Create React App 等现代工具链,默认开启 HMR,无需配置
  • 遇到 HMR 失效(如改了组件却没更新),先确认是否在支持的文件类型中(.jsx/.tsx/.vue)、是否有语法错误阻断更新、是否误写了 module.hot.decline()
  • 调试时可打开浏览器控制台,在 Network 标签页查看 hot-update.json.js 更新请求,确认变更是否被正确捕获
  • 避免在模块顶层写副作用代码(如直接调用 render()),应包裹进 accept 回调或组件生命周期内,否则更新后不会重新执行

基本上就这些。HMR 不是黑魔法,而是构建工具在可控边界内对模块系统的“温柔重写”。理解它依赖运行时介入和模块可管理性,比记住 API 更重要。

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

425

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

538

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

313

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

78

2025.09.10

全局变量怎么定义
全局变量怎么定义

本专题整合了全局变量相关内容,阅读专题下面的文章了解更多详细内容。

82

2025.09.18

python 全局变量
python 全局变量

本专题整合了python中全局变量定义相关教程,阅读专题下面的文章了解更多详细内容。

98

2025.09.18

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

516

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

287

2023.07.28

全国统一发票查询平台入口合集
全国统一发票查询平台入口合集

本专题整合了全国统一发票查询入口地址合集,阅读专题下面的文章了解更多详细入口。

19

2026.02.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Vue 教程
Vue 教程

共42课时 | 7.7万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号