freeCodeCamp/guide/chinese/react/fragments/index.md

1.7 KiB
Raw Blame History

title localeTitle
Fragments 片段

片段

片段是在不使用包装元素的情况下呈现多个元素的方法。在JSX中尝试渲染没有封闭标记的元素时您将看到错误消息Adjacent JSX elements must be wrapped in an enclosing tag 。这是因为当JSX进行转换时它会创建具有相应标记名称的元素并且如果找到多个元素则不知道要使用哪个标记名称。在过去经常解决这个问题的方法是使用包装div来解决这个问题。然而React的第16版带来了Fragment的添加,这使得不再需要它。

Fragment扮演包装器而不向DOM添加不必要的div。您可以直接从React导入中使用它或者解构它

import React from 'react'; 
 
 class MyComponent extends React.Component { 
  render(){ 
    return ( 
      <React.Fragment> 
        <div>I am an element!</div> 
        <button>I am another element</button> 
      </React.Fragment> 
    ); 
  } 
 } 
 
 export default MyComponent; 
// Deconstructed 
 import React, { Component, Fragment } from 'react'; 
 
 class MyComponent extends Component { 
  render(){ 
    return ( 
      <Fragment> 
        <div>I am an element!</div> 
        <button>I am another element</button> 
      </Fragment> 
    ); 
  } 
 } 
 
 export default MyComponent; 

React版本16.2进一步简化了此过程允许将空的JSX标记解释为片段

return ( 
  <> 
    <div>I am an element!</div> 
    <button>I am another element</button> 
  </> 
 ); 

更多信息: