react 函數子組件(Function ad Child Component)


今天學習了react中的函數子組件的概念,然后在工作中得到了實際應用,很開心,那么好記性不如爛筆頭,開始嘍~

函數子組件(FaCC )與高階組件做的事情很相似, 都是對原來的組件進行了加強,類似裝飾者。

FaCC,利用了react中children可以是任何元素,包括函數的特性,那么到底是如何進行增強呢?

分兩步走

第一步:class FetchDataParent 

import * as React from 'react'
import { get } from '../../common/fetch'
import { handleNotificate } from '@hi-ui/hiui/es/notification'

export default class WithRangeData extends React.PureComponent {
  constructor (props) {
    super(props)
    this.state = {
      data: []
    }
  }
  componentDidMount () {
// 從props中接收url,然后制作data,存入到自己的state中,具體處理邏輯,大家不用看
    const { url } = this.props
    get(url)
      .then(res => {
        if (res && res.status === 200) {
          const result = []
          res.data.forEach(element => {
            const { status, value } = element
            switch (status) {
              case 0:
                result.push({
                  name: value,
                  id: value
                })
                break
              default:
            }
          })
          this.setState({
            data: result
          })
        } else {
          handleNotificate({
            type: 'erroe',
            autoClose: true,
            title: '請求出錯',
            message: `請求出錯,原因:${res.message}`
          })
        }
      })
  }
  render () {
    const { children } = this.props
    const { data } = this.state
// 這里是關鍵,將自己state中的值,傳給children,直接執行了children(), 說明children是個函數
    return <div>
      {children(data)}
    </div>
  }
}

第二步:使用上面的父組件,

export default class AccessApply extends React.PureComponent {
   render(){
    // WithRangeData里的children是一個函數,接收父組件給的data,並return出自己想要的任何東西。
return ( <WithRangeData url={`${encyclopediaUrl.getPermissionDimensionValues}?id=${range.id}`} > { (data) => { return ( <div> <span>{range.nickname}</span> <Select mode='multiple'
             list={data}
onChange={(item) => { console.log('多選結果', item) }} /> </div> ) } } </WithRangeData> ) } }

 

總結:可以看到,函數子組件模式,也是給他的children傳遞一些數據,與高階組件很相似。

然而,FaCC不會再去創建一個新的Component,而HOC會創建一個新的Component然后傳遞props下去。 同時,FaCC這種模式,父組件與子組件的關系比較明顯,代碼更易讀。

高階組件優點:有完整的生命周期。FaCC中children直接執行,無生命周期。

 

最后,展示一下react 函數組件如何寫Facc:

const ClassNameWrapper = ({ children }) => children('demo-class')

// 使用

const HeadWithClass = (props) => (
  <ClassNameWrapper>
    {(class) => <header classNmae={class} ></header>}
  </ClassNameWrapper>
)

 

參考文章:https://segmentfault.com/a/1190000016269347


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM