React react.fragment和<>的使用及区别

React一个常用的模式是组件返回多个元素。Fragment可以为你的子元素分组而不需要在DOM上为它们添加额外的节点。

Fragment 使用

c 复制代码
render() {return (
 <React.Fragment> 
	 <ChildA /> 
	 <ChildB /> 
	 <ChildC /> 
 </React.Fragment> );}

短语法使用

这里有一种短语法可以用来声明Fragment,它看起来就像是空标签:

c 复制代码
class Columns extends React.Component {
	render() {
		return (
			<> 
				<td>Hello</td> 
				<td>World</td> 
			</> 
		); 
	}
}

两者区别

使用<React.Fragment>语法声明的Fragment是可以有key的。一个使用场景是将集合映射到一组Fragment数组。举个例子:创建一个描述列表:

c 复制代码
function Glossary(props) {
  return (
    <dl>
      {props.items.map(item => (
        // 没有`key`,将会触发一个key警告
        <React.Fragment key={item.id}>
          <dt>{item.term}</dt>
          <dd>{item.description}</dd>
        </React.Fragment>
      ))}
    </dl>
  );

key是唯一能传递给Fragment的属性。在未来,我们可能会支持其他如事件处理器的属性。

相关推荐
摸鱼的春哥25 分钟前
春哥的Agent通关秘籍12:本地RAG实战(中下)向量化与落库
前端·javascript·后端
明月_清风25 分钟前
毫秒级响应:前端本地搜索的“降维打击”
前端·indexeddb
摸鱼的春哥28 分钟前
专家实验让AI做战争决策,AI的选择太暴力了
前端·javascript·后端
明月_清风31 分钟前
存储配额:用 navigator.storage.estimate() 预判浏览器什么时候会删你的数据
前端·indexeddb
漂流瓶jz9 小时前
BEM、OOCSS、SMACSS、ITCSS、AMCSS、SUITCSS:CSS命名规范简介
前端·css·代码规范
陈随易13 小时前
真的,你可以不用TypeScript
前端·后端·程序员
郑州光合科技余经理13 小时前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
唐璜Taro14 小时前
Vue3 + TypeScript 后台管理系统完整方案
前端·javascript·typescript
dustcell.14 小时前
haproxy七层代理
java·开发语言·前端
掘金酱14 小时前
「寻找年味」 沸点活动|获奖名单公示🎊
前端·人工智能·后端