【发布时间】:2019-05-26 08:42:23
【问题描述】:
我已经用 webpack 和 HMR 搭建了一个 SSR 环境。有一个静态渲染的标记,该服务器传递给客户端和一个带有ReactDOM.hydrate() 方法的client.js 捆绑包。如果我更改我的源代码,HMR 可以正常工作,但会在控制台中发出警告,指出客户端代码和静态标记之间不匹配。
我正在使用带有webpack-dev-middleware 和webpack-hot-middleware 的快速服务器
我的 webpack 配置如下所示:
module.exports = {
mode: 'development',
entry: ['webpack-hot-middleware/client', './src/client.js'],
devServer: {
hot: true,
publicPath: '/'
},
plugins: [new HotModuleReplacementPlugin()],
module: {
rules: [{ test: /\.(js|jsx)$/, exclude: /node_modules/, loader: 'babel-loader' }]
},
resolve: {
extensions: ['.js', '.jsx']
},
output: {
filename: 'client.js',
path: path.resolve(__dirname)
}
};
我想知道是否有任何方法可以解决这个问题,因为我想不出任何想法来让我的标记与我所做的更改相匹配,或者我应该只是取消这些警告?
【问题讨论】:
标签: reactjs express server-side-rendering