Webpack Hot Middleware не работает и ошибок нет - PullRequest
0 голосов
/ 02 апреля 2019

Я пытаюсь использовать webpack-hot-middleware с webpack-dev-middleware и, несмотря на следующие инструкции для его реализации в моем приложении expressjs, я не могу заставить горячую перезагрузку работать над изменениями кода реакции, html, hbs или css.Я пропустил код в моей настройке?Нужно ли добавлять загрузчики, если я хочу выполнить горячую перезагрузку для всех форматов файлов, которые я упомянул?

Команда: nf run nodemon app.js

webpack.config.js:

const isDev = process.env.NODE_ENV === 'development';
const webpack = require('webpack');

module.exports = {
    mode: isDev ? 'development' : 'production',
    entry: {
        index: [
            "webpack-hot-middleware/client?path=/__webpack_hmr&timeout=20000",
            "./public/index.js"
        ]
    },
    output: {
        path: __dirname + "/dist",
        filename: "bundle.js"
    },
    module: {
        rules: [
            {   
                test: /\.js$/, 
                exclude: /node_modules/, 
                loader: "babel-loader"
            },
            {
                test: /\.(s*)css$/,
                use: [
                    'style-loader', 
                    'css-loader',
                    'sass-loader'
                ],
            }
        ]
    },
    plugins: [
        new webpack.HotModuleReplacementPlugin()
    ]
};

app.js:

var express = require('express');
var app = express();

var webpack = require('webpack');
var webpackDevMiddleware = require('webpack-dev-middleware');
var webpackHotMiddleware = require('webpack-hot-middleware');
var webpackConfig = require('./webpack.config.js');
var compiler = webpack(webpackConfig);

webpackConfig.entry["server"] = "webpack/hot/dev-server";
webpackConfig.entry["client"] = "webpack-hot-middleware/client";

var controllers = require('./app/controllers/routes');
var hbsHelper = require('./views/helpers/hbs-helper')(hbs);

//Port Setting
var port = process.env.PORT || 3000;

//Set Morgan as Logger
app.use(morgan('dev'));

//Set favicon
app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')))

// Tell express to use the webpack-dev-middleware and use the webpack.config.js
// configuration file as a base.
app.use(webpackDevMiddleware(compiler, {
    publicPath: webpackConfig.output.publicPath,
    serverSideRender: true,
    stats: { colors: true }
}));

app.use(webpackHotMiddleware(compiler,{
    log: console.log
}));
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...