上一节我学习了webpack-dev-middleware
,可是单独使用它并无实现热更新,因此这节我要学习搭配使用webpack-hot-middleware
,来实现热更新功能。html
咱们依然建立一个项目node
mkdir hot-middleware && cd hot-middleware
npm init -y
mkdir src dist
cd src && touch index.js block.js
cd ../dist && touch index.html
cd ../
touch server.js webpack.dev.config.js
复制代码
目录:webpack
├── dist
│ └── index.html
├── package.json
├── server.js
├── src
│ ├── block.js
│ └── index.js
└── webpack.dev.config.js
复制代码
下载须要的包:git
npm i webpack webpack-cli webpack-dev-middleware webpack-hot-middleware express --save-dev
复制代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>webpack-hot-middleware</title>
<!-- 引用打包后js文件 -->
<script src="./index.js"></script>
</head>
<body>
</body>
</html>
复制代码
'use strict'
import { test } from './block.js'
console.log('hello world~')
test()
// 接收热更新输出,只有accept才能被更新
if (module.hot) {
module.hot.accept();
}
复制代码
'use strict'
module.exports = {
test: function () {
console.log(12345)
}
}
复制代码
var webpack = require('webpack');
var path = require('path')
module.exports = {
mode: 'development', // 热更新只在开发模式下有用
entry: [
+ 'webpack-hot-middleware/client?path=/__webpack_hmr&timeout=20000', // 必须这么写,这将链接到服务器,以便在包从新构建时接收通知,而后相应地更新客户端
'./src/index.js'
],
output: {
path: path.resolve(__dirname, 'dist'),
publicPath: '/', // 服务器脚本会用到
filename: 'index.js'
},
plugins: [
+ new webpack.HotModuleReplacementPlugin(), // 启动HMR
+ new webpack.NoEmitOnErrorsPlugin() // 在编译出现错误时,使用 NoEmitOnErrorsPlugin 来跳过输出阶段。这样能够确保输出资源不会包含错误。
],
};
复制代码
const express = require('express');
const webpack = require('webpack');
const webpackDevMiddleware = require('webpack-dev-middleware');
const webpackHotMiddleware = require('webpack-hot-middleware');
const app = express();
const config = require('./webpack.dev.config.js'); // 引入配置文件
const compiler = webpack(config); // 初始化编译器
// 使用webpack-dev-middleware中间件
app.use(webpackDevMiddleware(compiler, {
publicPath: config.output.publicPath
}));
// 使用webpack-hot-middleware中间件,配置在console台输出日志
+ app.use(webpackHotMiddleware(compiler, {
+ log: console.log, path: '/__webpack_hmr', heartbeat: 10 * 1000
+ }));
// 使用静态资源目录,才能访问到/dist/idndex.html
app.use(express.static(config.output.path))
// Serve the files on port 3000.
app.listen(3000, function () {
console.log('Example app listening on port 3000!\n');
});
复制代码
咱们增长一个命令运行看看github
package.json 增长一个命令web
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
+ "server": "node server.js"
},
复制代码
npm run server
复制代码
浏览器查看http://localhost:3000/
express
效果已经出来,咱们发现此次比以前单独使用webpack--middleware
多了一行提示,由于咱们配置了热更新日志输出npm
[HMR] connected
复制代码
HMR- Hot Module Replacement
即热更新,这已经很明白地告诉咱们热更新已经链接上了,咱们来验证下。json
修改/src/block.js
后端
'use strict'
module.exports = {
test: function () {
console.log('abcd')
}
}
复制代码
咱们发现,请求只是多出来两行,并无刷新页面
到此,咱们就使用webpack-dev-middleware
和webpack-hot-middleware
实现了热更新。
详细配置请参考官方文档webpack-hot-middleware
webpack-dev-server
,还有有webpack-dev-middleware
搭配webpack-hot-middleware
的方式呢?由于webpack-dev-server
是封装好的,除了webpack.config
和命令行参数以外,很难去作定制型开发。而 webpack-dev-middleware
是中间件,能够编写本身的后端服务而后使用它,开发更灵活。
webpack学习之路(五)loader初识及经常使用loader介绍
webpack学习之路(三)webpack-dev-middleware
webpack学习之路(二)webpack-dev-server实现热更新
I am moving forward.