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的属性。在未来,我们可能会支持其他如事件处理器的属性。

相关推荐
晚霞的不甘19 小时前
Flutter for OpenHarmony3D DNA 螺旋可视化:用 Canvas 构建沉浸式分子模型
前端·数据库·经验分享·flutter·3d·前端框架
摘星编程20 小时前
React Native + OpenHarmony:Stepper步进器组件
javascript·react native·react.js
●VON20 小时前
React Native for OpenHarmony:简易计算器应用的开发与跨平台适配实践
javascript·react native·react.js
摘星编程1 天前
OpenHarmony + RN:Placeholder文本占位
javascript·react native·react.js
a1117761 天前
医院挂号预约系统(开源 Fastapi+vue2)
前端·vue.js·python·html5·fastapi
0思必得01 天前
[Web自动化] Selenium处理iframe和frame
前端·爬虫·python·selenium·自动化·web自动化
摘星编程1 天前
React Native鸿蒙:Loading加载动画效果
react native·react.js·harmonyos
行走的陀螺仪1 天前
uni-app + Vue3编辑页/新增页面给列表页传参
前端·vue.js·uni-app
摘星编程1 天前
React Native + OpenHarmony:Spinner旋转加载器
javascript·react native·react.js
We་ct1 天前
LeetCode 205. 同构字符串:解题思路+代码优化全解析
前端·算法·leetcode·typescript