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

相关推荐
大漠_w3cpluscom2 分钟前
前端怎么提升自己的CSS编写能力?
前端
我是若尘4 分钟前
大数据量渲染优化:分批渲染技术详解
前端
ruanCat4 分钟前
pnpm 踩坑实录:用 public-hoist-pattern 拯救被严格隔离坑掉的依赖
前端·npm·node.js
yuki_uix5 分钟前
渲染优化三件套:React.memo、useMemo、useCallback 的使用边界
前端·react.js
徐同保5 分钟前
如何为 Node.js 多层子进程启动调试(以 OpenClaw 为例)
前端
滕青山5 分钟前
基于 pdf-lib 的图片转PDF工具核心JS实现
前端·javascript·vue.js
yuki_uix6 分钟前
前端异步编程三板斧:从面试题到底层思维
前端·javascript
会联营的陆逊7 分钟前
Vite + Vue3 构建优化:CDN 外部化方案
前端·vue.js
毛骗导演8 分钟前
对话历史越来越长,OpenClaw 是怎么「压缩」掉的?——深读 Compaction 机制源码
前端·架构
广州华水科技9 分钟前
单北斗GNSS变形监测如何在大坝安全中发挥关键作用?
前端