欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React Fragment介紹與使用詳解

 更新時(shí)間:2021年11月10日 16:26:58   作者:_Boboy  
本文主要介紹了React Fragment介紹與使用詳解,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

前言

在向 DOM 樹批量添加元素時(shí),一個(gè)好的實(shí)踐是創(chuàng)建一個(gè)document.createDocumentFragment,先將元素批量添加到
DocumentFragment 上,再把 DocumentFragment 添加到 DOM 樹,減少了 DOM操作次數(shù)的同時(shí)也不會創(chuàng)建一個(gè)新元素。

和 DocumentFragment 類似,React 也存在 Fragment 的概念,用途很類似。在 React 16之前,F(xiàn)ragment 的創(chuàng)建是通過擴(kuò)展包 react-addons-create-fragment 創(chuàng)建,而 React 16 中則通過<React.Fragment></React.Fragment> 直接創(chuàng)建 ‘Fragment'。

Fragments出現(xiàn)動(dòng)機(jī)

一種常見模式是組件返回一個(gè)子元素列表。以此 React 代碼片段為例:

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

< Columns /> 需要返回多個(gè) 元素以使渲染的 HTML 有效。如果在 < Columns /> 的 render() 中使用了父 div,則生成的 HTML 將無效。

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

得到一個(gè) < Table /> 輸出:

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

Fragments 由此出現(xiàn)解決了這個(gè)問題。

React Fragment介紹與使用

React.Fragment 組件能夠在不額外創(chuàng)建 DOM 元素的情況下,讓 render() 方法中返回多個(gè)元素。一個(gè)常見模式是一個(gè)組件返回多個(gè)元素。Fragments 允許你將子列表分組,而無需向 DOM 添加額外節(jié)點(diǎn)。

理解起來就是在我們定義組件的時(shí)候return里最外層包裹的div往往不想渲染到頁面,那么就要用到我們的Fragment組件了。就和vue的<template ></ template >.

render() {
  return (
    <React.Fragment>
      Some text.
      <h2>A heading</h2>
    </React.Fragment>
  );
}

你也可以使用其簡寫語法 <></>。

render() {
  return (
    <>
      Some text.
      <h2>A heading</h2>
    </>
  );
}

另外react 16開始, render支持返回?cái)?shù)組,知道這個(gè)特性的人不在少數(shù)。這一特性已經(jīng)可以減少不必要節(jié)點(diǎn)嵌套。

import React from 'react';

export default function () {
    return [
        <div>1</div>,
        <div>2</div>,
        <div>3</div>
    ];
}

<React.Fragment> 與 <>區(qū)別

<></> 語法不能接受鍵值或?qū)傩裕?lt;React.Fragment>可以。

使用顯式 <React.Fragment> 語法聲明的片段可能具有 key。一個(gè)使用場景是將一個(gè)集合映射到一個(gè) Fragments 數(shù)組 - 舉個(gè)例子,創(chuàng)建一個(gè)描述列表:

function Glossary(props) {
  return (
    <dl>
      {props.items.map(item => (
        // 沒有`key`,React 會發(fā)出一個(gè)關(guān)鍵警告
        <React.Fragment key={item.id}>
          <dt>{item.term}</dt>
          <dd>{item.description}</dd>
        </React.Fragment>
      ))}
    </dl>
  );
}

key 是唯一可以傳遞給 Fragment 的屬性。未來可能會添加對其他屬性的支持,例如事件。

注意:簡寫形式<></>,但目前有些前端工具支持的還不太好,用 create-react-app 創(chuàng)建的項(xiàng)目可能就不能通過編譯。所以遇到這種情況很正常。

到此這篇關(guān)于React Fragment介紹與使用詳解的文章就介紹到這了,更多相關(guān)React Fragment內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React實(shí)現(xiàn)表單提交防抖功能的示例代碼

    React實(shí)現(xiàn)表單提交防抖功能的示例代碼

    在 React 應(yīng)用中,防抖(Debounce)技術(shù)可以有效地限制函數(shù)在短時(shí)間內(nèi)的頻繁調(diào)用,下面我們就來看看如何使用Lodash庫中的debounce函數(shù)實(shí)現(xiàn)React表單提交中實(shí)現(xiàn)防抖功能吧
    2024-01-01
  • 使用react在修改state中的數(shù)組和對象數(shù)據(jù)的時(shí)候(setState)

    使用react在修改state中的數(shù)組和對象數(shù)據(jù)的時(shí)候(setState)

    這篇文章主要介紹了使用react在修改state中的數(shù)組和對象數(shù)據(jù)的時(shí)候(setState),具有很好的參考價(jià)值,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • React拖拽調(diào)整大小的組件

    React拖拽調(diào)整大小的組件

    這篇文章主要為大家詳細(xì)介紹了React拖拽調(diào)整大小的組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • React引入css的三種方式小結(jié)

    React引入css的三種方式小結(jié)

    這篇文章主要介紹了React引入css的三種方式小結(jié),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • React項(xiàng)目使用ES6解決方案及JSX使用示例詳解

    React項(xiàng)目使用ES6解決方案及JSX使用示例詳解

    這篇文章主要為大家介紹了React項(xiàng)目使用ES6解決方案及JSX使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • React實(shí)現(xiàn)導(dǎo)入導(dǎo)出Excel文件

    React實(shí)現(xiàn)導(dǎo)入導(dǎo)出Excel文件

    本文主要介紹了React實(shí)現(xiàn)導(dǎo)入導(dǎo)出Excel文件,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-07-07
  • React操作DOM之forwardRef問題

    React操作DOM之forwardRef問題

    這篇文章主要介紹了React操作DOM之forwardRef問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 深入研究React中setState源碼

    深入研究React中setState源碼

    這篇文章主要介紹了深入研究React中setState源碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-11-11
  • react實(shí)現(xiàn)原生下拉刷新

    react實(shí)現(xiàn)原生下拉刷新

    這篇文章主要為大家詳細(xì)介紹了react實(shí)現(xiàn)原生下拉刷新,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 詳解Jotai Immer如何實(shí)現(xiàn)undo redo功能示例詳解

    詳解Jotai Immer如何實(shí)現(xiàn)undo redo功能示例詳解

    這篇文章主要為大家介紹了詳解Jotai Immer如何實(shí)現(xiàn)undo redo功能示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04

最新評論