react中key的用法是什么

在react中,key用于识别组件,可在DOM中的某些元素被增加或删除时识别哪些元素发生了变化,是一种身份标识;可以根据key来决定是销毁还是更新组件,若key相同,组件有变化就只更新组件相应的属性,若key不同,会销毁之前的组件重新渲染。

react中key的用法是什么

本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。

react中key的用法是什么

简单来说,react利用key来识别组件,它是一种身份标识标识,就像我们的身份证用来辨识一个人一样。每个key对应一个组件,相同的key react认为是同一个组件,这样后续相同的key对应组件都不会被创建。

Keys可以在DOM中的某些元素被增加或删除的时候帮助React识别哪些元素发生了变化。因此你应当给数组中的每一个元素赋予一个确定的标识。

react的diff算法是把key当成唯一id然后比对组件的value来确定是否需要更新的,所以如果没有key,react将不会知道该如何更新组件。

你不传key也能用是因为react检测到子组件没有key后,会默认将数组的索引作为key。

react根据key来决定是销毁重新创建组件还是更新组件,原则是:

key相同,组件有所变化,react会只更新组件对应变化的属性。

key不同,组件会销毁之前的组件,将整个组件重新渲染。

key的使用场景

在项目开发中,key属性的使用场景最多的还是由数组动态创建的子组件的情况,需要为每个子组件添加唯一的key属性值。那会有的人就会自然而然想到,key和动态渲染的子元素获取的index位置的值很接近,那不是可以直接用index附上key的值呢key={index}?

例如:

{dataList.map((item,index)=>{    return 
{item.name}
    })}

登录后复制

在你尝试过后会发现,报错没了,渲染也没问题不是很正常嘛?!但是强烈不推荐用数组index来作为key。

如果数据更新仅仅是数组重新排序或在其中间位置插入新元素,那么视图元素都将重新渲染。

例如:

本来index=2的元素向前移动后,那该元素的key不也同样发生了改变那这样会改变的Key就没有任何的存在意义,既然是作为“身份证”一样的存在,那就不容有失。当然,在你用key值创建子组件的时候,若数组的内容只是作为纯展示,而不涉及到数组的动态变更,其实是可以使用index作为key的。

推荐学习:《react视频教程》

以上就是react中key的用法是什么的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2933590.html

(0)
上一篇 2025年3月11日 20:33:19
下一篇 2025年3月6日 20:06:31

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • react怎么关闭eslint

    方法:1、利用“npm run eject”复制所有依赖文件和相应的依赖到项目中;2、在“package.json”中修改“”eslintConfig””项目的代码;3、若缺少依赖,需要重新安装依赖,利用“npm s…

    2025年3月11日
    200
  • react-redux有什么用

    “react-redux”的作用:1、将组件分为了容器组件和UI组件;2、取代redux中的“store.subscribe”监听组件的状态变化,用于渲染组件;3、配合redux使用,使组件轻松的拿到全局状态,方便组件间的通信。 本教程操作…

    2025年3月11日
    200
  • react dnd的用法是什么

    react dnd用于构建复杂的拖放界面,并保持组件之间的耦合,是一组react高阶组件;使用时只需用对应的API将目标组件包裹,即可实现拖动或接受拖动元素的功能;不需要判断拖动状态,只需在传入的spec对象中各个状态属性中做对应处理即可。…

    2025年3月11日 编程技术
    200
  • react withrouter的用法是什么

    react withrouter用于将一个组件包裹进Route里面,并将“react-router”的三个history、location、match对象传入props对象,引入语法为“import{withRouter}from&#823…

    2025年3月11日
    200
  • 什么时候使用react-redux

    使用“react-redux”的场景:1、用户的使用方式复杂时;2、不同身份的用户有不同的使用方式时;3、多个用户之间可以协作时;4、与服务器大量交互,或者使用了WebSocketView时;5、要从多个来源获取数据时。 本教程操作环境:W…

    2025年3月11日
    200
  • react跟vue的diff算法有什么区别

    区别:1、当节点元素类型相同,但className不同时,vue认为是不同类型元素,会删除重建,而react会认为是同类型节点,只修改节点属性;2、列表比对,vue采用从两端到中间的比对方式,而react则采用从左到右依次比对的方式。 本教…

    2025年3月11日
    200
  • 什么是React Fiber

    React Fiber是一个类似双向链表的数据结构;ReactDom会根据jsx,为每个dom节点生成一个fiber节点,child指向第一个子节点、sibling指向下一个兄弟节点、return指向父节点的数据结构就是fiber数据结构。…

    2025年3月11日
    200
  • react的ssr项目是什么

    在react中,ssr是“Server Side Rendering”的缩写,是服务器端渲染的意思;ssr是将同一个组件渲染为服务器端的HTML字符串并发送到浏览器,将这些静态标记”激活”为客户端上完全可交互的应用程…

    2025年3月11日
    200
  • react中forceupdate的用法是什么

    在react中,forceupdate()用于强制使组件跳过shouldComponentUpdate(),直接调用render(),可以触发组件的正常生命周期方法,语法为“component.forceUpdate(callback)”。…

    2025年3月11日
    200
  • react是不是mvvm框架

    react不是mvvm框架。mvvm框架需要有一个vm对象来映射view,也即vm对象的属性发生改变的时候,对应的视图部分会相对应更新;而react中并没有vm对象,有的是属性和状态,整体可作为View使用,所以react不是mvvm框架。…

    2025年3月11日
    200

发表回复

登录后才能评论