解决 Hydration failed 错误

힘센캥거루
2024년 12월 16일(수정됨)
2
72

1. 发现问题

浏览我创建的膳食网站时,突然发现了如下问题

啊……这种问题让人无法忍受……

解决 Hydration failed 错误-1

点击进去发现是 Hydration failed 的内容。

简单来说,就是服务器渲染的页面和客户端显示的页面不同。

原因多种多样。

解决 Hydration failed 错误-2

2. 官方文档

Nextjs 官方文档指出 hydration error 的原因如下:

  1. 错误的 HTML 标签使用

    1. <p> 标签内嵌 <p> 标签

    2. <p> 标签内嵌 <div> 标签

    3. <p> 标签内嵌 <ul> 标签或 <ol> 标签

  2. 使用类似 typeof window !== 'undefined' 的逻辑

  3. 在渲染逻辑中使用 windowlocalStorage 这样的浏览器 API

  4. 在渲染逻辑中使用 Date() 这样的时间依赖 API

  5. 修改 HTML 的浏览器扩展程序

  6. 错误的 CSS in JS 库

  7. 如 Cloudflare 自动缩小一样错误配置修改 HTML 响应的 Edge/CDN

但无论怎么看我都没有符合这些。

于是我进行了从头到尾的调试。

3. 调试过程

逐行注释代码并保存,以寻找是哪个部分引发了错误。

哦,原来在开发环境中开发是为了这个。

解决 Hydration failed 错误-3

在寻找错误时发现 Lunch 组件发生了错误……

明白了……

所以进去 Lunch 中再逐一注释。

解决 Hydration failed 错误-4

结果发现奇怪的是 input 标签是 hydration failed 的原因。

尝试了多种方法,发现所有隐藏元素的 className,如 scale-0, opacity-0 等都会引发错误!

想要换新又觉得不满意也麻烦。

4. 解决方案

解决 Hydration failed 错误-5

这种没用的错误就无视是答案。

真是不值一提却喧闹不休。

给相关元素添加 suppressHydrationWarning 属性。

解决 Hydration failed 错误-6

这样做了就不会报错了。

5. 后记

因为没有与我相同的案例所以摸索了很久。

自学编程有时连简单的问题都会走很多弯路。

希望这篇文章能有一点帮助。

관련 글

Next.js 全栈博客开发记
Next.js 全栈博客开发记
在第一次接触网页开发大约 1 年之后,我开始想着想要拥有一个属于自己的博客。于是我就大概花了 6 个月几乎只埋头做这件事。前端部分的功能,参考金度亨先生的博客就已经足够了。我用 mdx 搭建起一个博客,其实连一周都没花到。事实上,仅靠前端也并不会给博客运营带来什么大问题。有一阵子我也觉得,只要写 m...
使用 Caddy 实现 Next.js 无停机部署(本地服务器)
使用 Caddy 实现 Next.js 无停机部署(本地服务器)
每次一有想在主页上加点什么的念头就去 build,结果中间好像偶尔会有人访问。于是 Search Console 上的分数开始一点点往下掉。觉得这样不行,就开始思考要怎么做无停机部署。1. 两个项目文件夹 + 两个终端答案出乎意料地简单:开两个终端。在一个终端里 build,另一个终端里让服务器跑着...
谷歌搜索索引自动化 - Web Search Indexing API
谷歌搜索索引自动化 - Web Search Indexing API
继上次搞完 IndexNow 之后,也决定在谷歌这边做一下自动化。查了一下,发现谷歌是通过一个叫 Web Search Indexing 的 API 来支持这个功能的。1. 适用范围官方文档中,这个 API 正式支持的范围是招聘公告和流媒体视频服务。说是为了给对实时性要求高的内容创建索引用的,但搜了...
搜索索引生成自动化 - IndexNow
搜索索引生成自动化 - IndexNow
在向 Bing 提交站点收录时才发现,Bing 提供了一个叫做 IndexNow 的功能。核心在于,可以利用 API Key,在写完文章的瞬间就立刻发起索引请求。只要用 fetch 写出类似下面这样的请求,并把它串联到「写文章」流程里,就可以在把文章保存到 DB 的同时发送索引生成请求。POST /...
被入侵的 Nextjs、React 服务器经历
被入侵的 Nextjs、React 服务器经历
我最初接触到这次安全问题是在 12 月 5 日凌晨。据说在 React 中可以在未认证的情况下进行远程代码执行。看到这条新闻后,我虽然告诉了别人,但总觉得自己应该没事,就什么想法也没有地略过了。1. 发现被入侵的痕迹结果当我想登录更新博客代码时,在终端里发现了有命令被执行过的痕迹。/bin/sh:...
在博客中添加多语言功能(NextJS、next-intl、Vercel AI SDK)
在博客中添加多语言功能(NextJS、next-intl、Vercel AI SDK)
最近我觉得博客需要多语言功能。于是决定用 next-intl 来实现多语言服务。1.i18n首先,在做多语言服务时有一些必须遵守的原则。这被称为 internationalization,单词太长,所以把首字母 i 和尾字母 n,以及中间 18 个字母合在一起,写成 i18n。1) i18n 的原则...

댓글을 불러오는 중...