【问题标题】:Is there any way to avoid "Text content did not match" warning in SSR with React?有什么方法可以避免在 SSR 中使用 React 出现“文本内容不匹配”警告?
【发布时间】:2019-05-26 08:42:23
【问题描述】:

我已经用 webpack 和 HMR 搭建了一个 SSR 环境。有一个静态渲染的标记,该服务器传递给客户端和一个带有ReactDOM.hydrate() 方法的client.js 捆绑包。如果我更改我的源代码,HMR 可以正常工作,但会在控制台中发出警告,指出客户端代码和静态标记之间不匹配。

我正在使用带有webpack-dev-middlewarewebpack-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


    【解决方案1】:

    如果 suppressHydrationWarning 不起作用(例如,您想更深层次地抑制水合警告),您可以尝试在水合之前手动删除 DOM 内容。

    const rootId = 'app'
    const root = document.getElementById(vueRootId)
    root.innerHTML = ''
    // Your hydration code
    // ...
    

    请参阅Remove all child elements of a DOM node in JavaScript 了解删除 DOM 元素的子元素的替代方法。

    【讨论】:

      【解决方案2】:

      如果你将 suppressHydrationWarning 设置为 true,React 不会警告你该元素的属性和内容不匹配。它只工作一层深,旨在用作逃生舱口。

      <MyComponent suppressHydrationWarning />
      

      更多信息https://reactjs.org/docs/dom-elements.html#suppresshydrationwarning

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2019-03-03
        • 2018-05-01
        • 1970-01-01
        • 1970-01-01
        • 2015-04-18
        • 1970-01-01
        • 2023-04-04
        • 2022-10-06
        相关资源
        最近更新 更多