配置多入口 Webpack 热更新失效? #120

简介: 配置多入口 Webpack 热更新失效? #120

前言


Webpack 对于现代前端开发者,想必是相当熟悉了,在很多项目中,应用非常广泛,而 webpack-dev-server,相信大家应该也都接触过。最近,作者在配置多入口,热更新在单入口是好使的,结果到了多入口不好使?,然后通过 Google 寻找答案,找到了一篇 issueHMR not working with multiple entries,跟我的问题类似,好像真的有 BUG?看到作者回复

v4 修复了该问题,我丢,我还在使用 v3,翻看 v4 文档

此时,只有一个感觉,热更新都多久的东西了,不应该存在多入口,热更新有问题吧?升级到 v4 之后,还是不行,当时我这暴脾气就上来了,直接翻看源码。翻看源码之前,首先要对热更新是个什么,有个基础的了解。


模块热更新


模块热更新(Hot Module Replacement)是指在浏览器运行过程中,替换、添加或删除模块,而无需重新加载整个页面。

  • 保留在完全重新加载页面期间丢失的应用程序状态
  • 在源代码中对 CSS/JS 进行修改,会立刻在浏览器中进行更新,并只更新改变的内容,节省开发时间

对比 Live Reload 方案,HMR 体现了其强大之处,实时模块热刷新和保存应用状态,极大的提高了开发效率和开发体验。


启用模块热更新


HMR 的启用十分简单,一个带有热更新功能的 webpack.config.js 文件的配置如下:

const path = require('path');
module.exports = {
    // ...
    entry: {
        app: ['./src/index.js']
    },
    devServer: {
        contentBase: path.resolve(__dirname, 'dist'),
        hot: true,
        historyApiFallback: true,
        compress: true
    }
};

src/index.js

if (module.hot) {
    module.hot.accept();
}


原理


网上关于 Webpack 热更新原理文章很多,这里就不详细描述了,推荐几个。

调试


npm link

$ git clone https://github.com/webpack/webpack-dev-server.git

一定要找到你项目中对应的版本包,对号入座噢,否则会报错,把 webpack-dev-server 项目拉下来之后,尝试在 webpack-dev-server/lib/Server.js 该文件增加一行 console.log

然后进入根目录

$ cd webpack-dev-server
$ npm link

生成软链

cd 项目地址
npm link webpack-dev-server

link 成功之后,会提示下面,更换了 webpack-dev-server 地址

jiang@JiangdeMacBook-Pro-3 commonVideoClient % cnpm link webpack-dev-server
/Users/jiang/Desktop/commonVideoClient/node_modules/webpack-dev-server -> /usr/local/lib/node_modules/webpack-dev-server -> /Users/jiang/Desktop/webpack-dev-server

然后在项目跑 webpack-dev-server,在控制台应该就会看到对应的输出了,调试源码非常方便。

npm link 方案,第三方库和项目属于不同的项目,它们有自己的 node_modules,如果第三方库和项目都使用了同一个依赖,它们会在各自的 node_modules 去查

找,如果这个依赖不支持多例,应用就会异常。


yalc

在开发和创作多个包(私有或公共)时,您经常发现自己需要在本地环境中正在处理的其他项目中使用最新/WIP 版本,而无需将这些包发布到远程注册中心。NPM 和 Yarn 使用类似的符号链接包( npm/yarn link)方法解决了这个问题。虽然这在许多情况下可能有效,但它经常带来令人讨厌的约束和依赖解析、文件系统之间的符号链接互操作性等问题。

全局安装 yalc

npm install -g yalc

生成 yalc 包

$ cd webpack-dev-server
$ yalc publish

可以在自己本地 /Users/jiang/.yalc/packages/webpack-dev-server,找到对应的包

cd 项目地址
yalc link webpack-dev-server

link 后,可以在自己项目下,找到 .yalc

每次手动修改第三方库的代码,都需要手动 link,就很麻烦,对不对?ok,神器来了,nodemon

npm install -g nodemon
nodemon
--ignore dist/
--ignore node_modules/
--watch lib # 观察目录
-C # 只在变更后执行,首次启动不执行命令
-e js,ts,html,less,scss 监控指定后缀名的文件
--debug # 调试
-x "yalc publish" 自定义命令

然后,我们来试试这个工具,在 webpack-dev-server,新增三行可执行命令

运行下 npm run watch,然后每次修改,都会自动更新,是不是很舒服?



网页调试

找到对应的文件位置和代码行数,通过浏览器进行断点调试,这个就不展开讲了。


找到问题


经过一番折腾,升级 webpack-dev-server@v4,原理分析,源码调试,与之前正常的单页应用进行对比,发现都是正常的,还是不行,我就郁闷了,为何呢?突然之间,我悟了,好像多页应用没有在入口进行 module.hot

之前在 app.jsx 中写的 module.hot

改在入口文件 进行 module.hot

ok,成功,喜大普奔。


总结


带着问题,阅读源码是最高效的,这样你在阅读源码的过程中也不会感到无聊,因为你是要解决问题,才会去看源码,对于不懂的代码,一点一点调试,一步一步走下去,再结合现有的一些原理文章(站在巨人的肩膀上)就会找到答案。这次的经历,也算很有意思,感谢小伙伴们的阅读,喜欢的可以点个赞噢 🌟 ~

目录
相关文章
|
2月前
|
前端开发
在Webpack配置文件中,如何配置loader以处理其他类型的文件,如CSS或图片
在Webpack配置文件中,通过设置`module.rules`来配置loader处理不同类型的文件。例如,使用`css-loader`和`style-loader`处理CSS文件,使用`file-loader`或`url-loader`处理图片等资源文件。配置示例:在`rules`数组中添加对应规则,指定`test`匹配文件类型,`use`指定使用的loader。
|
2月前
|
缓存 前端开发 JavaScript
Webpack与Babel的进阶配置与优化
通过以上的进阶配置和优化策略,可以更好地发挥`Webpack`与`Babel`的功能,提高项目的性能和开发效率。
|
2月前
|
JavaScript 前端开发 UED
如何配置 Webpack 进行代码分离?
通过以上方法,可以有效地配置Webpack进行代码分离,根据项目的具体需求和场景选择合适的方式,能够显著提高应用的性能和用户体验。在实际应用中,还可以结合其他优化技术,进一步优化Webpack的打包结果和应用的加载速度。
72 5
|
2月前
|
前端开发 JavaScript
webpack相关配置
以上只是Webpack配置的一些常见部分,实际应用中还可以根据具体的项目需求和场景进行更复杂和细致的配置,以满足不同的构建和优化要求。
59 2
|
2月前
|
缓存 JavaScript 前端开发
配置 Webpack 进行代码分离的常见方法有哪些?
通过以上常见方法,可以根据项目的具体需求和场景,灵活地配置Webpack进行代码分离,从而提高应用的性能和加载速度,优化用户体验。
41 3
|
2月前
|
缓存 前端开发 JavaScript
前端性能优化:Webpack与Babel的进阶配置与优化策略
【10月更文挑战第28天】在现代Web开发中,Webpack和Babel是不可或缺的工具,分别负责模块打包和ES6+代码转换。本文探讨了它们的进阶配置与优化策略,包括Webpack的代码压缩、缓存优化和代码分割,以及Babel的按需引入polyfill和目标浏览器设置。通过这些优化,可以显著提升应用的加载速度和运行效率,从而改善用户体验。
72 6
|
2月前
|
缓存 前端开发 JavaScript
前端工程化:Webpack与Gulp的构建工具选择与配置优化
【10月更文挑战第27天】在现代前端开发中,构建工具的选择对项目的效率和可维护性至关重要。本文比较了Webpack和Gulp两个流行的构建工具,介绍了它们的特点和适用场景,并提供了配置优化的最佳实践。Webpack适合大型模块化项目,Gulp则适用于快速自动化构建流程。通过合理的配置优化,可以显著提升构建效率和性能。
66 2
|
JavaScript 前端开发
史上最走心webpack4.0中级教程——配置之外你应该知道的事
《webpack4.0各个击破系列》适合不满足于只会配置webpack但一时间又看不懂源码的中级读者。我没法保证这个系列是最好的,但至少能保证每一篇博文都跟那些Ctrl+C和Ctrl+V的博文有本质的区别,不信你读读看。
1794 0
|
4月前
|
JavaScript
webpack打包TS
webpack打包TS
139 60
|
3月前
|
缓存 前端开发 JavaScript
Webpack 打包的基本原理
【10月更文挑战第5天】
下一篇
开通oss服务