淺談 react高階組件-參數(shù)-高階函數(shù)

1. 前言

1.不廢話,書接上文react-高階組件初識,只講了個開頭
2.接下來繼續(xù)


2.參數(shù)

react-高階組件初識中,高階組件的參數(shù)只是一個組件,但是其實高階組件的參數(shù)還可以接收其他參數(shù),比如 根據(jù)傳遞的參數(shù)來獲取 storage的數(shù)據(jù)

2.1 高階組件代碼

    function withUserData(WrappedComponent,key) {
            return class extends React.Component {
                constructor(props){
                    super(props)
                    this.state= { userInfo:{} }

                }
                componentDidMount() {
                    //key傳遞過來的
                    let userInfo = JSON.parse(localStorage.getItem(key))
                    this.setState({ userInfo })
                }
                render() {
                    // ...this.props 傳遞給當(dāng)前組件的屬性繼續(xù)向下傳遞
                    return <WrappedComponent userInfo={this.state.userInfo} {...this.props} />
                }
            }
        }

1.其實沒有額外變化 只是根據(jù) key來獲取值
2.這里面為什么以 with開頭,其實是受react-router里面的 withRouter的影響


2.2 包裹組件也沒變化

   class UserView2 extends React.Component {
            render() {
                let { userInfo } = this.props
                return (
                    <div>
                        <h1>{userInfo.name}</h1>
                        <p>{userInfo.description}</p>
                    </div>
                )
            }
        }

2.3 聯(lián)合高階組件的使用

   const UserHOC = withUserData(UserView2,"userInfo")
        let App = () => {
            return (
                <div>
                    <h1>App</h1>
                    <UserHOC />
                </div>
            )
        }

就是多加個參數(shù)而已


3. 高階函數(shù)

3.1 基本概念

1.高階函數(shù),返回值是一個高階組件,所以也可以看成是高階組件的變種形式


3.2 整改

既然返回值是高階組件那就好說了

    const withUserData = (key)=>(WrappedComponent)=> {
            return class extends React.Component {
                constructor(props){
                    super(props)
                    this.state= { userInfo:{} }

                }
                componentDidMount() {
                    //key傳遞過來的
                    let userInfo = JSON.parse(localStorage.getItem(key))
                    this.setState({ userInfo })
                }
                render() {
                    // ...this.props 傳遞給當(dāng)前組件的屬性繼續(xù)向下傳遞
                    return <WrappedComponent userInfo={this.state.userInfo} {...this.props} />
                }
            }
        }

3.3 分析

1.高階組件作為返回值就行
2.上面的寫法和下面的寫法等價,箭頭函數(shù)的基礎(chǔ)

const withUserData2 = (key)=>(WrappedComponent)=>  class extends React.Component {}

3.4 WrappedComponent

WrappedComponent 這個包裹組件沒有變化


3.5 聯(lián)合使用

    const UserHOC = withUserData("userInfo")(UserView2)
        let App = () => {
            return (
                <div>
                    <h1>App</h1>
                    <UserHOC />
                </div>
            )
        }

1.這種寫法在 react-redux里面見到的比較多

export default connect(mapStateToProps, mapDispatchToProps)

2.類似這種,其實很多第三方庫都有,只是之前可能不太了解高階組件,高階函數(shù)給忽略掉了


參考資料

react-高階組件初識
react-redux 基礎(chǔ)
react-組件總結(jié)
react-高階組件-中文官網(wǎng)


初心

我所有的文章都只是基于入門昼捍,初步的了解;是自己的知識體系梳理,如有錯誤,道友們一起溝通交流;
如果能幫助到有緣人,非常的榮幸,一切為了部落的崛起;
共勉
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末现斋,一起剝皮案震驚了整個濱河市钻哩,隨后出現(xiàn)的幾起案子坦胶,更是在濱河造成了極大的恐慌惊窖,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,348評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件哀蘑,死亡現(xiàn)場離奇詭異诚卸,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)绘迁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,122評論 2 385
  • 文/潘曉璐 我一進(jìn)店門合溺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人脊髓,你說我怎么就攤上這事辫愉。” “怎么了将硝?”我有些...
    開封第一講書人閱讀 156,936評論 0 347
  • 文/不壞的土叔 我叫張陵恭朗,是天一觀的道長。 經(jīng)常有香客問我依疼,道長痰腮,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,427評論 1 283
  • 正文 為了忘掉前任律罢,我火速辦了婚禮膀值,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘误辑。我一直安慰自己沧踏,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,467評論 6 385
  • 文/花漫 我一把揭開白布巾钉。 她就那樣靜靜地躺著翘狱,像睡著了一般。 火紅的嫁衣襯著肌膚如雪砰苍。 梳的紋絲不亂的頭發(fā)上潦匈,一...
    開封第一講書人閱讀 49,785評論 1 290
  • 那天,我揣著相機(jī)與錄音赚导,去河邊找鬼茬缩。 笑死,一個胖子當(dāng)著我的面吹牛吼旧,可吹牛的內(nèi)容都是我干的凰锡。 我是一名探鬼主播,決...
    沈念sama閱讀 38,931評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼寡夹!你這毒婦竟也來了处面?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,696評論 0 266
  • 序言:老撾萬榮一對情侶失蹤菩掏,失蹤者是張志新(化名)和其女友劉穎魂角,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體智绸,經(jīng)...
    沈念sama閱讀 44,141評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡野揪,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,483評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了瞧栗。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片斯稳。...
    茶點故事閱讀 38,625評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖迹恐,靈堂內(nèi)的尸體忽然破棺而出挣惰,到底是詐尸還是另有隱情,我是刑警寧澤殴边,帶...
    沈念sama閱讀 34,291評論 4 329
  • 正文 年R本政府宣布憎茂,位于F島的核電站,受9級特大地震影響锤岸,放射性物質(zhì)發(fā)生泄漏竖幔。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,892評論 3 312
  • 文/蒙蒙 一是偷、第九天 我趴在偏房一處隱蔽的房頂上張望拳氢。 院中可真熱鬧,春花似錦蛋铆、人聲如沸馋评。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽栗恩。三九已至,卻和暖如春洪燥,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背乳乌。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工捧韵, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人汉操。 一個月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓再来,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子芒篷,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,492評論 2 348

推薦閱讀更多精彩內(nèi)容