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

React報錯Type '() => JSX.Element[]' is not assignable to type FunctionComponent

 更新時間:2022年12月19日 11:34:17   作者:chuck  
這篇文章主要為大家介紹了React報錯Type '() => JSX.Element[]' is not assignable to type FunctionComponent解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

總覽

當我們嘗試從函數(shù)組件中返回元素組成的數(shù)組時,會產生"Type '() => JSX.Element[]' is not assignable to type FunctionComponent"錯誤。為了解決該錯誤,可以將元素數(shù)組包裹在React片段中。

這里有個示例用來展示錯誤是如何發(fā)生的。

// App.tsx
import React from 'react';
// ?? Type '() => JSX.Element[]' is not assignable to type 'FunctionComponent<{}>'.
// Type 'Element[]' is missing the following properties
// from type 'ReactElement<any, any>': type, props, key ts(2322)
const App: React.FunctionComponent = () => {
  return ['Alice', 'Bob'].map(element => <div key={element}>{element}</div>);
};
export default App;

這是完全有效的React.js代碼,因為我們能夠從React的函數(shù)組件中返回一個數(shù)組。然而,FunctionComponent接口的返回類型是ReactElementnull

這也就意味著,我們可以只返回一個React元素或者null值。

React片段

為了解決該類型錯誤,我們必須將數(shù)組包裹在React片段(React fragment)中。

// App.tsx
import React from 'react';
const App: React.FunctionComponent = () => {
  return (
    <>
      {['Alice', 'Bob'].map(element => (
        <div key={element}>{element}</div>
      ))}
    </>
  );
};
export default App;

當我們需要對一個元素列表進行分組而不向DOM添加額外的節(jié)點時,就會用到片段。

React.Fragment

你可能還會看到使用了更加詳細的片段語法。

// App.tsx
import React from 'react';
const App: React.FunctionComponent = () => {
  return (
    <React.Fragment>
      {['Alice', 'Bob'].map(element => (
        <div key={element}>{element}</div>
      ))}
    </React.Fragment>
  );
};
export default App;

上面的兩個例子達到了相同的結果--它們對元素列表的元素進行分組,而沒有給DOM添加額外的節(jié)點。

div

另一個解決方案是將元素數(shù)組包裹在另一個DOM元素中,例如一個div。

// App.tsx
import React from 'react';
const App: React.FunctionComponent = () => {
  return (
    <div>
      {['Alice', 'Bob'].map(element => (
        <div key={element}>{element}</div>
      ))}
    </div>
  );
};
export default App;

這仍然符合FunctionComponent接口中指定的返回類型,因為我們的組件返回的是一個單一的React元素。

總結

為了解決"Type '() => JSX.Element[]' is not assignable to type FunctionComponent"錯誤,可以使用React片段或者div將元素數(shù)組進行包裹。

以上就是React報錯Type '() =&gt; JSX.Element[]' is not assignable to type FunctionComponent的詳細內容,更多關于React報錯FunctionComponent的資料請關注腳本之家其它相關文章!

相關文章

  • React項目經驗總結及遇到的坑

    React項目經驗總結及遇到的坑

    這篇文章主要介紹了React項目經驗總結,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07
  • React傳值 組件傳值 之間的關系詳解

    React傳值 組件傳值 之間的關系詳解

    這篇文章主要介紹了React傳值 組件傳值 之間的關系詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-08-08
  • react中useRef的應用使用詳解

    react中useRef的應用使用詳解

    這篇文章主要介紹了react中useRef的應用使用詳解的相關資料,需要的朋友可以參考下
    2023-05-05
  • 淺談React Component生命周期函數(shù)

    淺談React Component生命周期函數(shù)

    React組件有哪些生命周期函數(shù)?類組件才有的生命周期函數(shù),分為幾個階段:掛載,更新,卸載,錯誤處理,本文主要介紹了這個階段,感興趣的可以了解一下
    2021-06-06
  • 基于React封裝一個層次模糊效果的容器組件

    基于React封裝一個層次模糊效果的容器組件

    這篇文章主要為大家詳細介紹了如何基于React封裝一個層次模糊效果的容器組件,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2024-03-03
  • react實現(xiàn)一個優(yōu)雅的圖片占位模塊組件詳解

    react實現(xiàn)一個優(yōu)雅的圖片占位模塊組件詳解

    這篇文章主要給大家介紹了關于react如何實現(xiàn)一個還算優(yōu)雅的占位模塊圖片組件的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-10-10
  • 詳解如何使用Jest測試React組件

    詳解如何使用Jest測試React組件

    在本文中,我們將了解如何使用Jest(Facebook 維護的一個測試框架)來測試我們的React組件,我們將首先了解如何在純 JavaScript 函數(shù)上使用 Jest,然后再了解它提供的一些開箱即用的功能,這些功能專門用于使測試 React 應用程序變得更容易,需要的朋友可以參考下
    2023-10-10
  • React使用TailwindCSS的實現(xiàn)示例

    React使用TailwindCSS的實現(xiàn)示例

    TailwindCSS是一個實用優(yōu)先的CSS框架,本文主要介紹了React使用TailwindCSS的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • react 下拉框內容回顯的實現(xiàn)思路

    react 下拉框內容回顯的實現(xiàn)思路

    這篇文章主要介紹了react 下拉框內容回顯,實現(xiàn)思路是通過將下拉框選項的value和label一起存儲到state中, 初始化表單數(shù)據時將faqType對應的label查找出來并設置到Form.Item中,最后修改useEffect,需要的朋友可以參考下
    2024-05-05
  • 聊聊ant?design?charts?獲取后端接口數(shù)據展示問題

    聊聊ant?design?charts?獲取后端接口數(shù)據展示問題

    今天在做項目的時候遇到幾個讓我很頭疼的問題,一個是通過后端接口成功訪問并又返回數(shù)據,但拿不到數(shù)據值。其二是直接修改state中的data,console中數(shù)組發(fā)生變化但任然數(shù)據未顯示,這篇文章主要介紹了ant?design?charts?獲取后端接口數(shù)據展示,需要的朋友可以參考下
    2022-05-05

最新評論