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

淺談React的React.FC與React.Component的使用

 更新時(shí)間:2021年09月03日 15:00:33   作者:小小的咸魚(yú)哈  
本文主要介紹了React的React.FC與React.Component的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

React 的組件可以定義為 函數(shù)(React.FC<>)或class(繼承 React.Component) 的形式。

一、React.FC<>

1.React.FC是函數(shù)式組件,是在TypeScript使用的一個(gè)泛型,F(xiàn)C就是FunctionComponent的縮寫(xiě),事實(shí)上React.FC可以寫(xiě)成React.FunctionComponent:

const App: React.FunctionComponent<{ message: string }> = ({ message }) => (
  <div>{message}</div>
);

2.React.FC 包含了 PropsWithChildren 的泛型,不用顯式的聲明 props.children 的類(lèi)型。React.FC<> 對(duì)于返回類(lèi)型是顯式的,而普通函數(shù)版本是隱式的(否則需要附加注釋?zhuān)?/p>

3.React.FC提供了類(lèi)型檢查和自動(dòng)完成的靜態(tài)屬性:displayName,propTypes和defaultProps(注意:defaultProps與React.FC結(jié)合使用會(huì)存在一些問(wèn)題)。

4.我們使用React.FC來(lái)寫(xiě) React 組件的時(shí)候,是不能用setState的,取而代之的是useState()、useEffect等 Hook API。

例子(這里使用阿里的Ant Desgin Pro框架來(lái)演示):

const SampleModel: React.FC<{}> = () =>{   //React.FC<>為typescript使用的泛型
   const [createModalVisible, handleModalVisible] = useState<boolean>(false); 
   return{
   {/** 觸發(fā)模態(tài)框**/}
   <Button style={{fontSize:'25px'}}  onClick={()=>handleModalVisible(true)} >樣例</Button>
   {/** 模態(tài)框組件**/}
   <Model onCancel={() => handleModalVisible(false)} ModalVisible={createModalVisible} /> 
  }

二、class xx extends React.Component

如需定義 class 組件,需要繼承 React.Component。React.Component是類(lèi)組件,在TypeScript中,React.Component是通用類(lèi)型(aka React.Component<PropType, StateType>),因此要為其提供(可選)prop和state類(lèi)型參數(shù):

例子(這里使用阿里的Ant Desgin Pro框架來(lái)演示)::

class SampleModel extends React.Component {
  state = {
    createModalVisible:false,
  };

  handleModalVisible =(cVisible:boolean)=>{
    this.setState({createModalVisible:cVisible});
  };
  return {
  {/** 觸發(fā)模態(tài)框**/}
   <Button onClick={()=>this.handleModalVisible(true)} >樣例</Button>
   {/** 模態(tài)框組件**/}
   <Model onCancel={() => handleModalVisible(false)} ModalVisible={this.state.createModalVisible} /> 
  }

ps:簡(jiǎn)單來(lái)說(shuō),不知道用什么組件類(lèi)型時(shí),就用 React.FC。

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

相關(guān)文章

  • create-react-app修改為多頁(yè)面支持的方法

    create-react-app修改為多頁(yè)面支持的方法

    本篇文章主要介紹了create-react-app修改為多頁(yè)面支持的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-05-05
  • ReactJS中不同類(lèi)型的狀態(tài)詳解

    ReactJS中不同類(lèi)型的狀態(tài)詳解

    這篇文章主要為大家介紹了ReactJS中不同類(lèi)型的狀態(tài)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • 詳解react-native WebView 返回處理(非回調(diào)方法可解決)

    詳解react-native WebView 返回處理(非回調(diào)方法可解決)

    這篇文章主要介紹了詳解react-native WebView 返回處理(非回調(diào)方法可解決),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-02-02
  • react高階組件經(jīng)典應(yīng)用之權(quán)限控制詳解

    react高階組件經(jīng)典應(yīng)用之權(quán)限控制詳解

    在React中,高階組件是重用組件邏輯的一項(xiàng)高級(jí)技術(shù)。下面這篇文章主要給大家介紹了關(guān)于react高階組件經(jīng)典應(yīng)用之權(quán)限控制的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-09-09
  • react-router-dom簡(jiǎn)介(推薦)

    react-router-dom簡(jiǎn)介(推薦)

    react-router包含三種類(lèi)型的組件:路由組件、路由匹配組件?、導(dǎo)航組件,在你使用這些組件的時(shí)候,都必須先從react-router-dom引入,這篇文章主要介紹了react-router-dom簡(jiǎn)介,需要的朋友可以參考下
    2022-12-12
  • 阿里低代碼框架lowcode-engine設(shè)置默認(rèn)容器詳解

    阿里低代碼框架lowcode-engine設(shè)置默認(rèn)容器詳解

    這篇文章主要為大家介紹了阿里低代碼框架lowcode-engine設(shè)置默認(rèn)容器詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • 在React中強(qiáng)制重新渲染的4 種方式案例代碼

    在React中強(qiáng)制重新渲染的4 種方式案例代碼

    這篇文章主要介紹了在React中強(qiáng)制重新渲染的4 種方式,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2023-12-12
  • React?之最小堆min?heap圖文詳解

    React?之最小堆min?heap圖文詳解

    這篇文章主要為大家介紹了React?之最小堆min?heap圖文詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • react-native彈窗封裝的方法

    react-native彈窗封裝的方法

    這篇文章主要為大家詳細(xì)介紹了react-native彈窗封裝的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • Create?react?app修改webapck配置導(dǎo)入文件alias

    Create?react?app修改webapck配置導(dǎo)入文件alias

    這篇文章主要為大家介紹了Create?react?app修改webapck配置導(dǎo)入文件alias,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12

最新評(píng)論