- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图在 next.js 中执行一个简单的算法,但我遇到了这个水合作用错误。
这是我正在使用的代码:
import numeros from "../../functions/numberGenerators.js"
export default function teste(){
let number = numeros()
return number.map(n =>
<div key={n}>
Number: {n}
</div>)
}
和:
export default function megaSena(qtde = 6){
let listNumbers = []
while(listNumbers.length <= qtde - 1){
const numeroRandom = parseInt(Math.random() * 60) + 1
if (!listNumbers.includes(numeroRandom)){
listNumbers.push(numeroRandom)
}
}
return listNumbers
}
我遇到了以下错误:
1° - 错误:Hydration 失败,因为初始 UI 与服务器上呈现的内容不匹配。
2° - 错误:文本内容与服务器呈现的 HTML 不匹配。
3° - 错误:Hydration 失败,因为初始 UI 与服务器上呈现的内容不匹配。
4° - 错误:补水时出错。因为错误发生在 Suspense 边界之外,所以整个根将切换到客户端呈现。
我该怎么做才能解决这个问题?
最佳答案
这些错误消息本质上都在说同样的事情:
来自服务器的 HTML 与您的应用呈现的内容不匹配。
当 teste
被调用时,它并不总是返回相同的东西。它旨在显示随机数。
这意味着它会显示不同的数字列表,每次 teste
呈现。
当使用服务器端渲染 (SSR) 和像 NextJS 这样的框架时,它使用 React hydration .这只是一个花哨的词,表示 React 正在弄清楚如何从 HTML 文件中提取 DOM 结构并将其转换为正在运行的单页应用程序 (SPA)。
为了使其正常工作,React Hydration 要求来自服务器的 HTML 与您的客户端应用呈现的内容完全匹配。
所以在您的场景中,这就是正在发生的事情:
teste
,生成随机数字数组并呈现它。teste
,生成一个新随机数字数组并呈现它。修复很简单,但需要您注意何时需要或不需要。
常见的做法是利用 useEffect()
来确保服务器和客户端在水合过程中呈现相同的内容,并且只在客户端后处理呈现动态内容。
最简单的方法就是什么都不渲染。使用您的代码,它看起来像这样:
import React from "react";
export default function Teste() {
const [hydrated, setHydrated] = React.useState(false);
React.useEffect(() => {
setHydrated(true);
}, []);
if (!hydrated) {
// Returns null on first render, so the client and server match
return null;
}
let number = numeros();
return number.map((n) => <div key={n}>Number: {n}</div>);
}
这样做是为了确保第一次 Teste
呈现时它会返回 null
。
第一次呈现是服务器用来生成 HTML 文件的内容,也是客户端应用程序将用于“水合”过程的内容。
在第一次运行期间,hydrated
将具有默认值 false
,这将导致组件返回 null
。同样在第一次运行中,useEffect()
将调用 setHydrated(true)
,这将在第一次渲染完成后触发第二次渲染。
到第二次渲染运行时,应用程序已经水化,因此无需再担心发生错误。此时 hydrated
将为 true
,因此随机数将正常呈现。
如果你想了解更多关于 React hydration 的知识,我写了一篇 blog post about fixing these types of errors .
我还发布了一个 NPM 包,有助于简化处理这些类型的水合作用错误:react-hydration-provider
要使用 react-hydration-provider
修复错误,您的代码应如下所示:
import { HydrationProvider, Client } from "react-hydration-provider";
function App() {
return (
<HydrationProvider>
<Client>
<Teste />
</Client>
</HydrationProvider>
);
}
function Teste() {
let number = numeros();
return number.map((n) => <div key={n}>Number: {n}</div>);
}
这将使 Teste
仅在应用程序水化后在客户端呈现。
你也可以像这样做一些更复杂的事情:
import { HydrationProvider, Server, Client } from "react-hydration-provider";
function App() {
return (
<HydrationProvider>
<Teste />
</HydrationProvider>
);
}
function Teste() {
let number = numeros();
return number.map((n) => (
<div key={n}>
<span>Number: </span>
<Client>{n}</Client>
<Server>Loading...</Server>
</div>
));
}
这将允许您的应用程序最初为每个数字呈现一条加载消息,然后在应用程序完成水合过程后将其替换为随机数。
关于javascript - 错误 : Text content does not match server-rendered HTML,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/72673362/
我需要在每个渲染帧完成后拍摄屏幕截图,但我发现某些屏幕截图是重复的,所以我想知道是否可以在渲染完成之前保存屏幕截图。因此... renderer.render() 会阻塞直到完成渲染吗? 如果没有,有
web.py 骨架代码中的“render._keywords['globals']['render'] = render”是什么意思? http://webpy.org/skeleton/0.3 最佳
所以在我的 Nuxt universal-mode 应用程序中,我有时会出现错误: vue.runtime.esm.js:620 [Vue warn]: The client-side rendere
我想创建一个 portal-like effect使用 Bevy . Unity 似乎有一个 render texture实现这一目标。 有没有办法在 Bevy 中做同样的事情?如果没有, futur
我有一个看起来像这样的组件(非常简化的版本): const component = (props: PropTypes) => { const [allResultsVisible, setA
编辑:我调整了代码,但问题仍然存在。见下文 我有这个 p:selectOneRadio : 而这个 p:radioButton : 和 AData包含其
为了渲染部分我可以使用 render 'partial_name' 或 render partial: 'partial_name' 我开始知道 render 是 render partial 的简写
我注意到文章中的一些地方使用了 React.render() 和一些地方 ReactDOM.render()。这两者有什么具体区别吗? 最佳答案 这是 0.14 中引入的最新更改。他们将 React
我的代码是这样的: function render() { renderer.render( scene, camera ); renderer.clear(); } 我想知道为什么它
我目前正在实现 useSWR 以便从我的 express 和 mongo-db 后端获取数据。我能够从数据库中成功获取数据没问题。以下是我用来实现此目的的代码: ```//SWR method for
我只有在按照 React native - "this.setState is not a function" trying to animate background color? 的建议合并了 u
所以我有一个大的纹理,被分成 64x64 block 。 我使用将其加载到 LibGDX texture = new Texture("texturemap.png"); regions = Text
我对放置 @Scripts.Render 和 @Styles.Render 的位置感到很困惑。理想情况下,我会将它们全部放在 head 部分中,但出乎意料的是,例如 @Scripts.Render("
我正在尝试使用 jamon 来收集使用 Tapestry 的网站的统计信息(呈现网页的时间)。 我怎样才能拥有 服务器收到请求时执行的方法,即渲染开始时? 响应全部发送完毕,即渲染结束时执行的方法 ?
在我的 React 应用程序中,我想要渲染一个 prop 值,但直到渲染完成后更新 props 后它才存在。 this.props.users 是一个对象,因此我使用 Object.keys() 转换
我正在使用 React 的钩子(Hook),我希望有一个从数据库中检索到的值作为初始值。但是,我收到以下错误: Invariant Violation: Invariant Violation: Re
我正在尝试按照以下代码将多个场景包含到单个 webgl 渲染器中: renderer.render(scene1, camera); renderer.render(scene2, camera);
我在我的 xhtml 页面中使用此代码,当我运行应用程序时,元描述仍在呈现。我想根据某些条件使用元描述标签。主布局: ..........
我正在使用react-native-render-html来渲染html。renderers方法允许我提供自定义函数来呈现特定标签。不过,我想使用源代码中的原始内部 HTML 将子组件替换为我的自定义
我有一个网格,可以渲染可变高度的卡片。 为了获取卡片的高度,我将卡片渲染在 ReactHeight 中。 ( https://github.com/nkbt/react-height ),这让我可以在
我是一名优秀的程序员,十分优秀!