webpack-dev-serverを使用してJSおよびSCSSファイルのホットリロード機能を使用しようとしていますが、失敗します。次のように私が追加した私の/dist/main.cssをbabel、webpack、sassでホットリロードを使用できない
[WDS] App updated. Recompiling...
[WDS] App hot update...
[HMR] Checking for updates on the server...
[HMR] The following modules couldn't be hot updated: (They would need a full reload!)
[HMR] - 381
[HMR] Nothing hot updated.
[HMR] App is up to date.
と私のindex.htmlにファイルを/dist/main.js、残りは次のとおりです:私は同じエラーを取得しておくよ
私server.jsは次のとおりです。
const webpack = require('webpack');
const WebpackDevServer = require('webpack-dev-server');
const config = require('./webpack.config');
new WebpackDevServer(webpack(config), {
publicPath: config.output.publicPath,
hot: true,
historyApiFallback: true
}).listen(3000, 'localhost', function (err, result) {
if (err) {
return console.log(err);
}
console.log('Listening at http://localhost:3000/');
});
マイwebpack.configファイルは次のとおりです。
const sassLoaders = [
'css-loader?minimize!',
'postcss-loader',
'sass-loader?includePaths[]=' + path.resolve(__dirname, './src/css')
]
module.exports = {
entry: [
'babel-polyfill',
'webpack-dev-server/client?http://localhost:3000',
'webpack/hot/only-dev-server',
path.normalize(__dirname + '/src/js/main'),
path.normalize(__dirname + '/src/css/styles.scss')
],
devtool: 'cheap-module-source-map',
output: {
filename: '[name].js',
path: path.join(__dirname, './dist'),
publicPath: '/dist'
},
module: {
loaders: [
{
loader: 'babel',
test: /\.js$/,
include: [path.resolve(__dirname, 'src', 'js')],
query: {
plugins: ['transform-runtime'],
presets: ['es2015']
}
},
{
test: /\.scss$/,
loader: ExtractTextPlugin.extract('style-loader', sassLoaders.join('!'))
}
]
},
plugins: [
new ExtractTextPlugin('[name].css'),
new webpack.optimize.UglifyJsPlugin({
compress: { warnings: false }
}),
new webpack.HotModuleReplacementPlugin()
],
postcss: [
autoprefixer({
browsers: ['last 2 versions']
})
],
resolve: {
extensions: ['', '.js', '.scss'],
root: [path.join(__dirname, './src')]
}
};
ありがとうございました!