当前位置: 首页 > news >正文

【React】useId

在 React 中,useId 是 React 18 引入的一个 Hook,用于生成一个在组件生命周期中保持稳定的唯一 ID。它主要用于:

  • 无障碍(accessibility)场景,比如表单控件需要一个 idlabelhtmlFor 属性配对。
  • 服务端渲染(SSR) 与客户端渲染保持一致。
  • 避免多个组件生成的 ID 冲突。

🧠 为什么不用自己写 id

以前开发者会自己写逻辑生成 id,比如用 Math.random()Date.now()uuid 生成,但这些在服务端渲染(SSR)和客户端渲染中可能不一致,从而导致 水合(hydration)错误

SSR:服务端渲染出 html 内容,发给浏览器,浏览器接收到 html,先展示静态内容,然后加载动态js,就是将html激活(水合),然后就生成了动态应用,但是这样服务端和浏览器端的 id 生成就会不同(可能随机数生成等等)。


useId 的基本语法

const id = useId();
  • id 是一个 字符串,React 会自动加前缀,确保唯一性。

🧪 示例:表单中 label 与 input 关联

import React, { useId } from 'react';function NameInput() {const id = useId();return (<div><label htmlFor={id}>姓名:</label><input id={id} type="text" /></div>);
}

在这个例子中:

  • labelhtmlForinputid 使用同一个值。
  • useId() 保证了 ID 在每次渲染中一致,适用于 SSR。

🧩 示例:多个组件实例

function InputField({ label }) {const id = useId();return (<div><label htmlFor={id}>{label}</label><input id={id} type="text" /></div>);
}function Form() {return (<><InputField label="用户名" /><InputField label="邮箱" /></>);
}

每个 InputField 都会生成不同的 id,即使组件重复使用也不会冲突。


⚠️ 注意事项

  1. useId 不能用在事件处理函数或条件判断内部
  2. 它不能替代 key、uuid 等复杂 ID 生成需求(比如数据库 ID)。
  3. 如果你要生成 带后缀的 ID,可以这样做:
const id = useId();
<input id={`${id}-email`} />

🎯 适用场景总结

场景是否推荐用 useId
labelinput/textarea 等的 ID 配对✅ 是
ARIA 属性如 aria-labelledby✅ 是
SSR 页面保持一致性✅ 是
用于生成数据库 ID、URL 等❌ 否

如果在使用 React 17 或更低版本,可以用第三方库如 uuidnanoid 作为替代,但在 React 18+ 推荐用 useId 来保证一致性和性能。

http://www.lqws.cn/news/174691.html

相关文章:

  • 基于ReAction范式的问答系统实现demo
  • 如何以 9 种方式将照片从手机传输到笔记本电脑
  • 青少年编程与数学 01-011 系统软件简介 05 macOS操作系统
  • 第二十八章 RTC——实时时钟
  • WebRTC源码线程-1
  • 【大模型LLM学习】Flash-Attention的学习记录
  • 永磁同步电机无速度算法--基于卡尔曼滤波器的滑模观测器
  • 2.1 Windows编译环境介绍
  • Go 中 map 的双值检测写法详解
  • C语言字符数组输入输出方法大全(附带实例)
  • C#报错 iText.Kernel.Exceptions.PdfException: ‘Unknown PdfException
  • 20N60-ASEMI太阳能逆变器专用20N60
  • Web前端基础:HTML-CSS
  • API是什么意思?如何实现开放API?
  • 打卡day46
  • 智能手表健康监测系统的PSRAM存储芯片CSS6404LS-LI—高带宽、耐高温、微尺寸的三重突破
  • Web 架构之缓存策略实战:从本地缓存到分布式缓存
  • 拦截器执行流程——补充
  • AI 模型分类全解:特性与选择指南
  • TDengine 替换 Hadoop,彻底解决数据丢失问题 !
  • 第R9周:阿尔茨海默病诊断(优化特征选择版)
  • LeetCode--23.合并k个升序链表
  • 单元测试与QTestLib框架使用
  • 三十四、面向对象底层逻辑-SpringMVC九大组件之FlashMapManager接口设计哲学
  • 使用Matplotlib创建炫酷的3D散点图:数据可视化的新维度
  • 结构体和指针1
  • SSIM、PSNR、LPIPS、MUSIQ、NRQM、NIQE 六个图像质量评估指标
  • 无头浏览器技术:Python爬虫如何精准模拟搜索点击
  • 如何写高效的Prompt?
  • 数据库正常,但后端收不到数据原因及解决