图解 Webpack 4.x 热更新原理 All In One
图解 Webpack 4.x 热更新原理 All In One
Webpack
HMR
⚠️ module.hot & module.hot.accept
if (module.hot) {
module.hot.accept('./index.js', function() {
console.log('✅🔥🚀 在 APP 的入口统一控制 HMR');
// app();
})
}
模块模块热替换
原理
https://webpack.docschina.org/concepts/hot-module-replacement/
guide
https://webpack.docschina.org/guides/hot-module-replacement
API
https://webpack.docschina.org/api/hot-module-replacement/
https://webpack.docschina.org/plugins/hot-module-replacement-plugin/
WDS
/ webpack-dev-server
https://webpack.js.org/guides/development
https://github.com/webpack/webpack-dev-server
https://webpack.docschina.org/configuration/dev-server/#devserverhot
hot
module.exports = {
//...
devServer: {
hot: true
}
};
hotOnly
module.exports = {
//...
devServer: {
hotOnly: true
}
};
WDM
/ webpack-dev-middleware
https://webpack.js.org/guides/development/#using-webpack-dev-middleware
https://github.com/webpack/webpack-dev-middleware
$ npm i -D express webpack-dev-middleware
webpack.config.js
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const { CleanWebpackPlugin } = require('clean-webpack-plugin');
module.exports = {
mode: 'development',
entry: {
app: './src/index.js',
print: './src/print.js',
},
devtool: 'inline-source-map',
devServer: {
contentBase: './dist',
},
plugins: [
new CleanWebpackPlugin({ cleanStaleWebpackAssets: false }),
new HtmlWebpackPlugin({
title: 'Output Management',
}),
],
output: {
filename: '[name].bundle.js',
path: path.resolve(__dirname, 'dist'),
// dev-server path
publicPath: '/',
},
};
https://www.npmjs.com/package/webpack-dev-middleware#usage
const webpack = require('webpack');
const middleware = require('webpack-dev-middleware');
const compiler = webpack({
// webpack options
});
const express = require('express');
const app = express();
app.use(
middleware(compiler, {
// webpack-dev-middleware options
})
);
app.listen(3000, () => console.log('Example app listening on port 3000!'));
dev-server 🔑
https://webpack.js.org/configuration/dev-server/#devserverpublicpath-
module.exports = {
//...
devServer: {
publicPath: '/assets/'
}
};
module.exports = {
//...
devServer: {
publicPath: 'http://localhost:8080/assets/'
}
};
refs
https://time.geekbang.org/course/detail/100028901-98391
https://zhuanlan.zhihu.com/p/52465785
https://juejin.im/post/6844904008432222215
https://github.com/luobotang/webpack-hmr-demo
https://www.jianshu.com/p/652fbae768bf
https://mp.weixin.qq.com/s/2L9Y0pdwTTmd8U2kXHFlPA
©xgqfrms 2012-2021
www.cnblogs.com/xgqfrms 发布文章使用:只允许注册用户才可以访问!
原创文章,版权所有©️xgqfrms, 禁止转载 🈲️,侵权必究⚠️!
本文首发于博客园,作者:xgqfrms,原文链接:https://www.cnblogs.com/xgqfrms/p/13487959.html
未经授权禁止转载,违者必究!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)
2019-08-11 IndexedDB & bug
2016-08-11 类型参考表(C# 参考):内置类型表(C# 参考) : 类型(C# 编程指南)
2016-08-11 Key Bindings for Visual Studio Code