淺談React的React.FC與React.Component的使用
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è)面支持的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-05-05詳解react-native WebView 返回處理(非回調(diào)方法可解決)
這篇文章主要介紹了詳解react-native WebView 返回處理(非回調(diào)方法可解決),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-02-02react高階組件經(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阿里低代碼框架lowcode-engine設(shè)置默認(rèn)容器詳解
這篇文章主要為大家介紹了阿里低代碼框架lowcode-engine設(shè)置默認(rèn)容器詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02在React中強(qiáng)制重新渲染的4 種方式案例代碼
這篇文章主要介紹了在React中強(qiáng)制重新渲染的4 種方式,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-12-12Create?react?app修改webapck配置導(dǎo)入文件alias
這篇文章主要為大家介紹了Create?react?app修改webapck配置導(dǎo)入文件alias,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12