理解 React 18 中的 useId Hooks

本文探讨React 18中的useId Hooks,它用于生成唯一且稳定的id,适用于同构应用,解决服务器端和客户端id不一致的问题,以及在表单中的应用。useId解决了水合和可访问性问题,但在某些场景如映射列表时不应使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

React 18 带有许多特性,例如自动批处理、并发和新的 Hooks。

这些 Hooks 通常都有非常明确的使用目的,比如 useTransition 用于处理 React 中的转换;useSyncExternalStore 用来读取外部数据源。

本文将深入探讨 useId ,它的用途以及一些其他方案的对比。

同构:useId 和 random、uuid

同构是指在服务器端和客户端之间共享相同的代码,这意味着服务器端代码也可以在客户端运行。

React 支持开箱即用的同构,在同构应用中渲染列表时,如果我们没有一个唯一的 id,很多人习惯使用 Math.random 或类似 uuid 这样的库来生成一个唯一 id。但这些方法有一个共同的缺点:当程序运行时,由服务端生成的 uuid 或 Math.random 会和客户端生成的不同。

这种 id 不匹配会导致水合和可访问性的问题。

在 useId 之前,React 有一个 useOpaqueIdentifier Hook,它是 useId 的第一个版本,但是它有很多问题。经过 React 团队的重构,它被重命名为 useId。

useId 的作用非常简单,生成一个唯一且稳定的 id,可以在应用的服务端或客户端使用。useId 生成的 Id 无论是在服务器端还是客户端都是稳定的。

id 还负责处理可访问性问题,这意味着可访问性 API 可以使用这些 id 将组件链接在一起。使用 useId 也可以解决水合问题。

useId 使用方法

使用 useId 非常简单,只需调用 useId,它会返回一个值,然后使用这个值就可以了。具体示例可以看下面的代码:

import { useId } from 'react';
import './App.css';

function App() {const firstId = useId();const secondId = useId()return <div className="App"><h3>The first id generated is {firstId}</h3><h3>The second id generated is {secondId} and different from {firstId} </h3></div>;
}

export default App; 

首先从 React 导入 useId。接下来从 useId 中获取两个随机 id,并在我们的组件中显示这些 id。我们看到的页面应该如下图所示:

在表单中使用 useId

使用 useId 的另外一个场景是表单。

我们可以给 useId 添加附加信息,拼接出唯一的字符串。如下面的代码所示:

import { useId } from 'react';
import './App.css';
function App() {const firstId = useId();const secondId = useId();return (<div className="App"><form><div><label htmlFor={`${firstId}-email`}>Email</label><input id={`${firstId}-email`} type="text" placeholder="Your email" /></div><div><label htmlFor={`${secondId}-password`}>Password</label><inputid={`${secondId}-password`}type="password"placeholder="Your password"/></div></form></div>);
}
export default App; 

在上面的代码中,我们将附加信息附加到生成的 ID 中,比如 xx-email。这种方法可以将额外的信息添加到生成的 ID 中。

你可以看到下图所示的结果:

什么时候使用 useId?什么时候不用?

我们现在已经了解了 useId 的用处;接下来要知道的事情就是要知道该在什么时候使用它,什么时候不使用它。

你应该在以下情况下使用 useId:

  • 你想生成唯一 ID
  • 你想要连接 HTML 元素,比如 label 和 input。

在以下情况下不应该使用 useId:

  • 映射列表后需要 key。
  • 你需要定位 CSS 选择器。useId 会返回一个包含冒号的字符串,如上面的示例所示。CSS 选择器不支持从 useId 中生成的字符串。
  • 你正在使用不可变的值。

最后

为大家准备了一个前端资料包。包含54本,2.57G的前端相关电子书,《前端面试宝典(附答案和解析)》,难点、重点知识视频教程(全套)。



有需要的小伙伴,可以点击下方卡片领取,无偿分享

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值