मेरे पास पग और स्टाइलस के साथ एक एक्सप्रेस ऐप है। मैंने एचएमआर मिडलवेयर को कॉन्फ़िगर किया है और यह स्टाइलस परिवर्तनों पर पुनः लोड होता है लेकिन पग परिवर्तनों के लिए नहीं।पग + एक्सप्रेस में परिवर्तनों का पता लगाने के लिए वेबपैक हॉट रीलोड कैसे प्राप्त करें?
मुझे आश्चर्य है कि क्या मुझे एक विशिष्ट कॉन्फ़िगरेशन गुम है। मैंने pug-html-loader
जोड़ने का भी प्रयास किया लेकिन यह भी काम नहीं करता था। https://webpack.js.org/loaders/raw-loader/
Webpack 3 config:
module: {
rules: [
{
test: /\.pug$/,
use: [
{loader: 'raw-loader'},
{loader: 'pug-html-loader'}
]
}
]
},
plugins: [
// Templates HTML
new HtmlWebpackPlugin({
filename: 'index.html',
template: './src/templates/index.pug'
}),
new HtmlWebpackPlugin({
filename: 'contact.html',
template: './src/templates/contact.pug'
}),
new webpack.NamedModulesPlugin(),
new webpack.HotModuleReplacementPlugin()
]
// 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()]
}
पग बस वेबपैक में जावास्क्रिप्ट में परिवर्तित होने जा रहा है, क्योंकि स्टाइल लोडर के विपरीत, यह ऑटो लोड नहीं हो सकता है, यह एचएमआर के साथ अद्यतन करने के लिए समर्थन में बनाया गया है। अपनी पग फ़ाइलों को एचएमआर संगत बनाने के लिए आपको 'if (module.hot) {module.hot.accept ('आदि का उपयोग करने की आवश्यकता है। प्रतिक्रिया एक और प्लगइन है जो एचएमआर के समर्थन में बनाई गई है, क्योंकि पग सिर्फ एक टेम्पलेटिंग इंजन है और नहीं क्लास/ऑब्जेक्ट घटक जो आपको स्वयं एचएमआर को संभालने के लिए है। एचएमआर मैन्युअल रूप से हैंडलिंग करने के उदाहरण के लिए यहां देखें -> https://webpack.js.org/guides/hot-module-replacement/ – Keith