码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • webpack的热重载/热更新HMR是如何实现的


    概念

    关键词:热更新/热重载/HMR(Hot Module Replacement)
    效果:浏览器的无刷新更新,允许在运行时替换,添加,删除各种模块,而无需进行完全刷新重新加载整个页面
    目的:加快开发速度,所以只适用于开发环境下使用

    疑惑

    平时使用HMR的时候,我都会有这样的疑惑?

    1. webpack 会将不同的模块打包成不同 bundle 或 chunk 文件, 但是在使用 webpack 进行 dev 模式开发的时候,我并没有在我的 dist 目录中找到 webpack 打包好的文件,它们去哪了呢?
    2. 这些文件是怎么替换的?

    核心原理

    1. 使用 webpack-dev-server (后面简称 WDS)托管静态资源,同时以 Runtime 方式注入 HMR 客户端代码
    2. 浏览器加载页面后,与 WDS 建立 WebSocket 连接
    3. Webpack 监听到文件变化后,增量构建发生变更的模块,并通过 WebSocket 发送 hash 事件
    4. 浏览器接收到 hash 事件后,请求 manifest 资源文件,确认增量变更范围
    5. 浏览器加载发生变更的增量模块
    6. Webpack 运行时触发变更模块的 module.hot.accept 回调,执行代码变更逻辑(回调可选)
      在这里插入图片描述

    参考资料

    https://www.cnblogs.com/liangyin/p/16579708.html

  • 相关阅读:
    html 常见兼容性问题
    06 | 基于Docker构建企业Jenkins CI平台
    文件真实类型识别 - linux c file
    Win10安装TensorRT
    eclipse 配置selenium环境
    应用商店备案登记流程解析
    iOS 关于UIProgressView、UIActivityIndicatorView常见使用方法
    python 爬虫书籍:如何使用Python爬虫爬取Web数据
    电脑如何设置开机密码?详细教程来了
    【前端面试知识题】- 4.2 JavaScript
  • 原文地址:https://blog.csdn.net/weixin_43972437/article/details/127492098
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号