1

Webpack と React Hot Loader v3 を使用しています。開発中は、ほとんど期待どおりに動作しています。ただし、静的バンドルファイルを出力すると、ホットロード機能が無効になると予想していました

webpack --progress -p

しかし、代わりに得られるのは、この種のエラーが繰り返されることです。

ここに画像の説明を入力

これは私の Webpack 構成です。

var path = require('path');
var webpack = require('webpack');

module.exports = {
    devServer: {
        publicPath: '/js/',
        hot: false,
        historyApiFallback: true,
        port: process.env.PORT || 3000
    },
    devtool: 'eval-source-map',
    entry: [
        'react-hot-loader/patch',
        'webpack-dev-server/client?http://localhost:3000',
        'webpack/hot/only-dev-server',
        './js/app/index'
    ],
    output: {
        path: path.join(__dirname, '/web/js/'),
        filename: 'bundle.js',
        publicPath: '/js/'
    },
    plugins: [
        new webpack.HotModuleReplacementPlugin()
    ],
    module: {
        loaders: [
            {
                test: /\.css$/,
                loader: "style-loader!css-loader?modules",
            },
            {
                test: /\.js$/,
                exclude: /(node_modules|bower_components)/,
                loader: 'babel',
                query: {
                    presets: ['es2015', 'react', 'stage-0'],
                    plugins: ['transform-flow-strip-types'],
                    cacheDirectory: true
                },
                include: path.join(__dirname, '/js/')
            }
        ]
    }
};

を無効にしてみてくださいという提案を受けましたHotModuleReplacementPlugin()が、それでも同じエラーが発生します。ここで何が欠けているかについてのアイデアはありますか?

4

2 に答える 2

4

エントリに開発サーバーまたはホットローダーを含まない別の運用構成が必要です。私の webpack 構成の簡略化されたバージョンについては、以下を参照してください。アプリがwebpack -pthenのようなもので実行されている場合LAUNCH_COMMANDproductionproductionConfigが使用されます。

しかし、これは 1 つのアプローチにすぎません。本番用に別の構成ファイルを用意することもできます。のようなものwebpack.prod.config.js。そして、実行webpack -pする代わりに、で本番構成を指定しますwebpack -p --config webpack.prod.config.js。繰り返しますが、実稼働構成にはエントリにwebpack-dev-serverorが含まれません。hot-loader

import webpack from 'webpack'
import path from 'path'
import HtmlWebpackPlugin from 'html-webpack-plugin'

const HtmlWebpackPluginConfig = new HtmlWebpackPlugin({
  template: path.join(__dirname, '/app/index.html'),
  filename: 'index.html',
  inject: 'body',
})

const PATHS = {
  app: path.join(__dirname, 'app'),
  build: path.join(__dirname, 'dist'),
}

const LAUNCH_COMMAND = process.env.npm_lifecycle_event

const isProduction = LAUNCH_COMMAND === 'production'
process.env.BABEL_ENV = LAUNCH_COMMAND

const productionPlugin = new webpack.DefinePlugin({
  'process.env': {
    NODE_ENV: JSON.stringify('production'),
  },
})

const base = {
  output: {
    path: PATHS.build,
    filename: 'index_bundle.js',
  },
}

const developmentConfig = {
  entry: [
    'webpack-dev-server/client?http://localhost:8080',
    'webpack/hot/only-dev-server',
    './app/index',
  ],
}

const productionConfig = {
  entry: [
    './app/index',
  ],
}

export default Object.assign({}, base,
  isProduction === true ? productionConfig : developmentConfig)
于 2016-06-01T16:57:18.340 に答える
1

を取り除くだけでなくHotModuleReplacementPlugin、余分なエントリ ポイントも取り除く必要があります。

// Current
entry: [
    'react-hot-loader/patch',
    'webpack-dev-server/client?http://localhost:3000',
    'webpack/hot/only-dev-server',
    './js/app/index'
],

// Fixed
entry: [
    './js/app/index'
],
于 2016-06-01T10:44:17.743 に答える