加载中...

React 16.2 Fragments组件语法片段的使用

吴佳
2019-09-12 16:47:41
分类:React
6037
7
0

什么是Fragments?

React中一个常见模式是为一个组件返回多个元素。Fragments可以让你聚合一个子元素列表,并且不在DOM中增加额外节点。
当然,会Vue的朋友就会发现,它好像与Vue的template很像,都可以用来表示一个空的节点。但是它与Vue的temlate还是有点不同的,我们都知道Vue的组件template里面它的子级是只能存在一个节点的,而react的Fragments子级是可以存在多节点的,所以这也正式两者不同之处。

为什么使用Fragments?

首先,先来看一个示例

//Columns
class Columns extends React.Component {
  render() {
    return (
      <div>
        <td>Hello</td>
        <td>World</td>
      </div>
    );
  }
}

//Table
class Table extends React.Component {
  render() {
    return (
      <table>
        <tr>
          <Columns />
        </tr>
      </table>
    );
  }
}

可以看到,在table组件tr中,渲染了Columns组件,而最终的输出是这样的

<table>
  <tr>
    <div>
      <td>Hello</td>
      <td>World</td>
    </div>
  </tr>
</table>

根据上方输出结构可以看到,tr下面多了一个div,造成了dom结构出现了非法嵌套,最终HTML将会是无效的。而这并不是为们想要的,所以Fragments的出现就是为了解决这样的问题。

如何使用Fragments?

我们就上方的示例进行更改

//Columns
class Columns extends React.Component {
  render() {
    return (
      <React.Fragment>
        <td>Hello</td>
        <td>World</td>
      </React.Fragment>
    );
  }
}

//Table
class Table extends React.Component {
  render() {
    return (
      <table>
        <tr>
          <Columns />
        </tr>
      </table>
    );
  }
}

最终输出

<table>
  <tr>
    <td>Hello</td>
    <td>World</td>
  </tr>
</table>

如果你觉得上方语法还是比较麻烦,不用着急,jsx提供了一个简写语法,示例如下

//Columns
class Columns extends React.Component {
  render() {
    return (
      <>
        <td>Hello</td>
        <td>World</td>
      </>
    );
  }
}

你可以像使用其他元素一样使用<></>,不过它不支持键值或属性。

请注意, 目前许多工具都不支持这个简写语法 , 所以你可能需要明确地使用 <React.Fragment> ,直到工具支持这个语法。

带key的Fragments

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的属性。未来,可能增加额外的属性支持,比如事件处理。

扫码关注后,回复“资源”免费领取全套视频教程

前端技术专栏

7

发表评论(共0条评论)

请输入评论内容
啊哦,暂无评论数据~