這篇文章帶給大家的內容是關於React中的函數子組件和高階組件的詳解 ,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。
在接觸過React專案後,大多數人都應該已經了解過或則用過了HOC(High-Order-Components)和FaCC(Functions as Child Components),因為這兩個模式在大多數react的開源庫裡都存在。例如react-router裡面的withRouter 就是典型的高階元件,接受一個元件回傳另一個經過增強的元件。而react-motion中的Motion就是典型的FaCC的應用。
HOC和FaCC兩者做的事也是非常相似的,都是類似設計模式裡面的裝飾者模式。都是在原有的實例或則單元上進行功能的增強。
當然不只是一些開源函式庫中會使用,在平常的程式碼編寫中,也有很多地方是適用於使用HOC和FaCC去封裝一些邏輯。例如資料埋點,新特性的toggle,取得轉換資料等。對於增強程式碼可讀性和邏輯重複使用來說,非常有用的。
高階函數我們都用過,就是接受一個函數然後回傳一個經過封裝的函數:
const plus = first => second => (first + second) plus(1)(2) // 3
而高階元件就是高階函數的概念應用到高階元件上:
const withClassName = ComposedComponent => props => ( <ComposedComponent {...props} className='demo-class' /> ) // 使用 const Header = text => (<header>{text}</header>) const headerWitheClass = withClassName(Header)
接受一個元件傳回一個經過包裝的新元件。在我們常使用的withRouter
就是在原始元件props
上面在加上localtion
等屬性。除了加入props以外高階元件還能做到:
在真正呼叫元件前後做一些事,例如埋點資料等
判斷元件是否該render,或該render其他的東西,例如出錯之後render錯誤頁面
傳遞props並增加新的props
const withTitleChange = ComposedComponent => { return class extends React.Component { componentDidMount () { const { title } = this.props document.title = title } render () { const props = this.props return <ComposedComponent {...props} /> } } }FaCC
const ClassNameWrapper = ({ children }) => children('demo-class') // 使用 const HeadWithClass = (props) => ( <ClassNameWrapper> {(class) => <header classNmae={class} ></header>} </ClassNameWrapper> )在FaCC中你也可以像HOC一樣在生命週期中做很多事對原有的組件進行封裝,基本上HOC能做的FaCC也都能做。我所在的專案之前都是大範圍的使用HOC,再經過一番討論後,開始大範圍的轉變成FaCC。 區別
Component Injection
的模式,有興趣的同學可以讀一讀。// HOC example import View from './View' const DetailPage = withServerData(withNavigator(View))
// FaCC example import View from './View' const DetailPage = props => ( <FetchServerData> { data => ( <Navigator> <View data={data} {...props} /> </Navigator> ) } </FetchServerData> )如果在上面再增加2個HOC,上面組合的過程就變得十分難看。而FaCC相對而言,如何封裝,資料來源來自那裡,元件接受了那些資料都比較顯眼。 效能最佳化 在HOC中我們能接受到宿主的prop,因為props是從HOC往下傳遞的,所以我們也有完整的生命週期,我們可以使用shouldComponentUpdate優化。而FaCC則不然,無法在其內部做比較props,除非在組合的時候外部在包一個組件才能進行比較props。
FaCC 在組合階段相對HOC更為靈活,他並不規定被增強組件如何使用它傳遞下去的屬性。而HOC基本上在寫完後就定死了。
另外,FaCC不會再去建立一個新的Component,而HOC會建立一個新的Component然後傳遞props下去。
###總結######社群中許多開源函式庫已經使用了兩種模式,也有很多的文章可以比較。也有很多激烈討論,當然對於最後解決問題而言,兩種模式都有好處。出於不同的考慮,可能選擇不一樣。 ######相關推薦:#########React高階元件實例解析################React中受控元件和非受控元件實例詳解#############以上是React中的函數子組件和高階組件的詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!