0

0

React 中 key 属性失效的常见原因与正确用法详解

心靈之曲

心靈之曲

发布时间:2026-02-18 13:16:08

|

700人浏览过

|

来源于php中文网

原创

React 中 key 属性失效的常见原因与正确用法详解

React 报错“Each child in a list should have a unique ‘key’ prop”通常是因为 key 未设置在直接子元素上,或被错误地放在了条件渲染的内部节点中;本文通过真实案例解析 key 的作用域规则、Fragment 正确用法及常见陷阱。

react 报错“each child in a list should have a unique ‘key’ prop”通常是因为 `key` 未设置在**直接子元素**上,或被错误地放在了条件渲染的内部节点中;本文通过真实案例解析 key 的作用域规则、fragment 正确用法及常见陷阱。

在 React 列表渲染中,key 是一个特殊且必需的属性,它并非传递给组件的普通 props,而是由 React 内部用于识别列表中每个元素的稳定标识符。关键原则是:key 必须赋给由 map() 直接返回的 JSX 元素(即列表的直接子节点),而非其内部嵌套结构。

回顾原始代码问题:

{Object.entries(userRoleMenu[UserRole]).map((item, index) => <>
  {item[0] === 'fpv' ? (
    <MenuItem key={item[0]} /* ❌ 错误:key 在条件分支内,但 Fragment <> 没有 key */ />
  ) : (
    <MenuItem key={item[0]}>{item[0]}</MenuItem>
  )}
</>)}

此处根本性错误在于:...>(即 React.Fragment)作为 map 的返回值,是列表的直接子节点,但它本身没有 key。而内部的 虽有 key,却只是 Fragment 的子元素——React 要求的是 列表每一项的顶层容器 具备唯一 key,而非其子孙节点。

✅ 正确解法是将 key 显式赋予 React.Fragment(或使用带 key 的 ),确保每个 map 项的顶层具备唯一标识:

<MenuList width={'148px'}>
  {Object.entries(userRoleMenu[UserRole]).map((item, index) => (
    <React.Fragment key={item[0]}>
      {item[0] === 'fpv' ? (
        <MenuItem
          _hover={{ backgroundColor: 'gray.50' }}
          onClick={() => handleMenuClick(item)}
        >
          {/* fpv 专属内容,例如图标或自定义标签 */}
          <Icon as={FpvIcon} mr={2} />
          FPV 控制台
        </MenuItem>
      ) : (
        <MenuItem
          _hover={{ backgroundColor: 'gray.50' }}
          onClick={() => handleMenuClick(item)}
        >
          {item[0]}
        </MenuItem>
      )}
    </React.Fragment>
  ))}
</MenuList>

⚠️ 注意事项:

  • key 不可动态生成(如 key={Math.random()})或使用 index(当列表可能增删/重排时会导致状态错乱);优先使用数据本身的稳定 ID(如 item[0] 作为菜单键名是合理选择);
  • 条件渲染中若需返回多个并列元素,必须包裹在带 key 的 Fragment 中,不可省略;
  • onClick={handleMenuClick(item)} 是常见错误写法(立即执行函数),应改为 onClick={() => handleMenuClick(item)} 或 onClick={useCallback(() => handleMenuClick(item), [item])} 防止重复创建函数;
  • 若 item[0] 存在重复风险(如后端数据异常),建议添加校验或改用组合键(如 ${item[0]}-${index})作为兜底方案。

总结:key 是 React 协调列表更新的“锚点”,它的位置必须精准落在 map 返回的 JSX 顶层节点上。理解这一机制,能从根本上避免 “unique key error”,并写出更健壮、可维护的列表渲染逻辑。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

371

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

339

2023.10.25

mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

195

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

304

2024.02.23

java标识符合集
java标识符合集

本专题整合了java标识符相关内容,想了解更多详细内容,请阅读下面的文章。

272

2025.06.11

c++标识符介绍
c++标识符介绍

本专题整合了c++标识符相关内容,阅读专题下面的文章了解更多详细内容。

138

2025.08.07

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

36

2025.11.16

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

561

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 5.2万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1万人学习

React核心原理新老生命周期精讲
React核心原理新老生命周期精讲

共12课时 | 1.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号