我正在开发一个React应用程序,并已设置webpack将我的代码打包成捆绑包。
但是,当我使用React DevTools在Chrome中加载我的应用程序并尝试通过扩展程序修改组件的道具时,它不会更改值或使用新值重新渲染。
以下是我的webpack.config.js
'use strict';
const webpack = require('webpack')
module.exports = {
entry: {
agile: './client/js/agile.jsx.js',
vendor: [
'domready',
'react',
'react-dom',
'classnames'
]
},
output: {
filename: '[name].bundle.js',
path: 'public/js',
publicPath: '/js/'
},
module: {
loaders: [
{ test: /\.js$/, exclude: /node_modules/, loader: 'babel' }
]
},
plugins: [
new webpack.optimize.DedupePlugin(),
new webpack.optimize.OccurenceOrderPlugin(true),
new webpack.optimize.CommonsChunkPlugin({names: ['vendor'], minChunks: Infinity}),
new webpack.HotModuleReplacementPlugin()
],
target: 'web',
devtool: 'source-map',
stats: {
color: true,
modules: false,
reasons: false
},
devServer: {
hot: true,
inline: true,
contentBase: './public/'
}
};
如果我做错了,请告诉我。
我还尝试删除上面使用的HotModuleReplacementPlugin
并在没有webpack-dev-server
的情况下运行我的应用。他们都没有工作。
版本:
答案 0 :(得分:7)
我不知道这是否有资格作为答案,但我还没有超过50分,所以我无法添加评论。
看起来这是由1月首次报道的React optimization引起的问题。在该线程的末尾有一个打开的PR,可以解决问题。