Mam aplikację Express z mopsami i rysikiem. Skonfigurowałem oprogramowanie pośredniczące HMR i przeładowuje się na zmiany trzpienia, ale nie na zmiany mopsów.Jak uzyskać ponowne ładowanie pakietu internetowego w celu wykrycia zmian w mopsie + ekspresie?
Zastanawiam się, czy brakuje mi konkretnej konfiguracji. Próbowałem też dodać pug-html-loader
, ale to też nie działa.
// server.js
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'pug');
const webpackDevMiddleware = require('./hmr').dev;
const webpackHotMiddleware = require('./hmr').hot;
app.use(webpackDevMiddleware);
app.use(webpackHotMiddleware);
// hmr.js
const webpackDevMiddleware = require('webpack-dev-middleware');
const webpackHotMiddleware = require('webpack-hot-middleware');
const webpack = require('webpack');
const webpackConfig = require('./webpack.config.js');
const compiler = webpack(webpackConfig);
exports.dev = webpackDevMiddleware(compiler, {
noInfo: true,
filename: webpackConfig.output.filename,
publicPath: webpackConfig.output.publicPath,
stats: {
colors: true
}
});
exports.hot = webpackHotMiddleware(compiler, {
log: console.log,
path: '/__webpack_hmr',
heartbeat: 10000
});
// webpack.config.js
const javascriptRule = {
test: /\.js$/,
use: [
{
loader: 'babel-loader',
options: {
presets: ['env']
}
}
]
};
const stylesRule = {
test: /\.styl$/,
use: ['style-loader', 'css-loader', 'stylus-loader']
};
module.exports = {
context: path.join(__dirname, 'javascripts'),
entry: [
'webpack-hot-middleware/client?path=/__webpack_hmr&timeout=20000',
'./index.js'
],
devtool: 'source-map',
output: {
path: path.join(__dirname, 'public', 'dist'),
filename: 'bundle.js',
publicPath: '/dist/',
library: 'aux'
},
module: {
rules: [javascriptRule, stylesRule]
},
plugins: [new webpack.HotModuleReplacementPlugin(), new webpack.NoEmitOnErrorsPlugin()]
}
Mops zostanie przekształcony w Javascript w pakiecie sieci Web, jako że nie może automatycznie się załadować, w przeciwieństwie do modułu ładującego styl, ma wbudowaną obsługę aktualizacji za pomocą HMR. Aby uczynić twoje pliki Pug kompatybilnymi z HMR musisz użyć 'if (module.hot) {module.hot.accept (' itp. React to kolejna wtyczka, która wbudowała obsługę HMR, ponieważ Pug jest tylko silnikiem szablonowym, a nie Komponent Class/Object, który będzie musiał sam obsługiwać HMR. Zobacz tutaj przykład ręcznego przenoszenia HMR -> https://webpack.js.org/guides/hot-module-replacement/ – Keith