成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

更快助你弄懂React-高階組件

dreamGong / 945人閱讀

摘要:等價于是一個返回函數(shù)的函數(shù)就是個高階函數(shù)返回的函數(shù)就是一個高階組件,該高階組件返回一個與關聯(lián)起來的新組件的也是一樣的總結一下高階組件是對代碼進行更高層次重構的好方法,如果你想精簡你的和生命周期方法,那么高階組件可以幫助你提取出可重用的函數(shù)。

談到react,我們第一個想到的應該是組件,在react的眼中可真的是萬物皆組件。就連我們獲取數(shù)據(jù)用到的axios也可以用組件來表示...比如,我們可以這樣封裝

{}} /* called on success of axios request - optional */
  onLoading={()=>{}} /* called on start of axios request - optional */
  onError=(error)=>{} /* called on error of axios request - optional */
/>

在項目中我們可以這樣寫

import { AxiosProvider, Request, Get, Delete, Head, Post, Put, Patch, withAxios } from "react-axios"
...
render() {
  return (
    
{(error, response, isLoading, makeRequest, axios) => { if(error) { return (
Something bad happened: {error.message}
) } else if(isLoading) { return (
Loading...
) } else if(response !== null) { return (
{response.data.message}
) } return (
Default message before request is made.
) }}
) }

有點過分了...至少我是覺得還是要根據(jù)個人的代碼習慣來吧,如果所有組件都是這么處理請求的,包括一些簡單的get請求,我覺得真的沒這個必要,并且我們的一些通用API也不太好統(tǒng)一管理

那么,高階組件到底是什么?

a higher-order component is a function that takes a component and returns a new component.

右鍵翻譯 ------> 高階組件就是一個函數(shù),且該函數(shù)接受一個組件作為參數(shù),并返回一個新的組件。
嗯,看起來就是這么簡單,其實用起來也是

1、具體來說一下,我們先用高階函數(shù)來舉個例子,一個 showUserPermit, 一個showUserVipInfo,兩個函數(shù)先從localStorage讀取了userVIP,之后針對userVIP做了一些處理。

function showUserPermit() {
   let vip = localStorage.getItem("u_V");
   console.log(`您可以享受的${u_V}的特權...`);
}

function showUserVipInfo() {
   let vip = localStorage.getItem("u_V");
   console.log(`您當前VIP等級為${u_V},升級立刻...`);
}

showUserPermit();
showUserVipInfo();

2、我們發(fā)現(xiàn)了兩個API中有兩個完全一樣的代碼,很冗余,這樣不好,我們改一下吧

function showUserPermit(u_V) {
   console.log(`您可以享受的${u_V}的特權...`);
}

function showUserVipInfo(u_V) {
   console.log(`您當前VIP等級為${u_V},升級立刻...`);
} 

3、這樣寫看上去確實簡單了一些,但是這兩個API要想保證功能完全必須依賴參數(shù)u_V,所有在調用這兩個函數(shù)之前我們都必須要拿到這個參數(shù),這樣未免有點耦合性,我們再次改造
function showUserPermit(u_V) {

   console.log(`您可以享受的${u_V}的特權...`);
}

function showUserVipInfo(u_V) {
   console.log(`您當前VIP等級為${u_V},升級立刻...`);
}

function wrapU_V(wrappedFunc) {
    let newFunc = () => {
        let vip = localStorage.getItem("u_V");
        wrappedFunc(vip);
};
    return newFunc;
}

module.exports = { 
    showUserPermit: wrapU_V(showUserPermit), 
    showUserVipInfo: wrapU_V(showUserVipInfo)
}

4、wrapU_V就是一個沒有任何副作用的高階函數(shù),那么他的意義是什么?又做了什么?它幫我們處理了u_V,并且調用了目標函數(shù)(函數(shù)參數(shù)),這樣當你再次使用導出的showUserPermit的時候根本不必要去關心u_V高低是怎么來的,到底需求什么外部條件,你只要知道它能幫我實現(xiàn)我想要做的事情就可以了!同時省去了每一次調用前都先要看一下它的參數(shù)是什么?怎么來?甚至根本不用關心wrapU_V內部是如何實現(xiàn)的,Array.map,setTimeout都可以稱為高階函數(shù)

高階組件
高階組件就是一個沒有副作用的純函數(shù),對就是一個函數(shù)
我們將上面的例子用component來重構一下

import React, {Component} from "react"
...

class showUserPermit extends Component {
    constructor(props) {
        super(props);
        this.state = {
            VIP: ""
        }
    }

    componentWillMount() {
        let VIP = localStorage.getItem("u_V");
        this.setState({
            VIP
        })
    }

    render() {
        return (
            
showUserPermit... {this.state.VIP}
) } } export default showUserPermit; /* - */ import React, {Component} from "react" ... class showUserVipInfo extends Component { constructor(props) { super(props); this.state = { VIP: "" } } componentWillMount() { let VIP = localStorage.getItem("u_V"); this.setState({ VIP }) } render() { return (
showUserVipInfo... {this.state.VIP}
) } } export default showUserVipInfo;

剛才發(fā)現(xiàn)的問題都可以映射在這兩個組件里了
按照上面的思路我們做一個處理

import React, {Component} from "react"

module.exports = Wrap: (WrappedComponent) => {
    class reComponent extends Component {
        constructor() {
            super();
            this.state = {
                VIP: ""
            }
        }

        componentWillMount() {
            let VIP = localStorage.getItem("u_V");
            this.setState({
                VIP
            })
        }

        render() {
            return 
        }
    }

    return reComponent
}

再來簡化一下 showUserVipInfo和showUserPermit組件

import React, {Component} from "react";
import {Wrap} as templete from "wrapWithUsername";

class showUserPermit extends Component {

    render() {
        return (
            
showUserPermit {this.props.username}
) } } showUserPermit = templete(showUserPermit); export default showUserPermit; /*--*/ import React, {Component} from "react"; import {Wrap} as templete from "wrapWithUsername"; class showUserVipInfo extends Component { render() { return (
showUserVipInfo {this.props.username}
) } } showUserPermit = templete(showUserPermit); export default showUserVipInfo;

并且高階組件中可以分布多個目標組件,舉一個我們項目中的例子


這里面右上角的時間選擇組件以及echarts組件是兩種不同身份特有的一些行為和樣式,其它的完全是一樣的,包括state以及共用方法都一模一樣。上代碼

render() {
  return (
    
...
<**GenTimerComponent** receiveTimeChange={this.getData.bind(this)}/>
...
<**EchartsComponent** chartData={this.state.chartData}/>
)

其中GenTimerComponent,和EchartsComponent都是目標組件,我們這樣導出

豁然開朗了吧,其實就是把兩個組件相同的地方或者都可能用到的地方抽離出來,說句題外話,其實本來是"高階組件"嵌套了目標組件,但是重新生成的新組建反倒是繼承了目標組件,看起來是一種控制反轉,和Vue中的extend+minix也比較像,通過繼承目標組件,除了一些靜態(tài)方法,包括生命周期,state,fun,我們都可得到
現(xiàn)在理解react-redux的connect函數(shù)~
把redux的state和action創(chuàng)建函數(shù),通過props注入給了Component。
你在目標組件Component里面可以直接用this.props去調用redux state和action創(chuàng)建函數(shù)了。

ConnectedComment = connect(mapStateToProps, mapDispatchToProps)(Component);  

等價于

// connect是一個返回函數(shù)的函數(shù)(就是個高階函數(shù))
const enhance = connect(mapStateToProps, mapDispatchToProps);
// 返回的函數(shù)就是一個高階組件,該高階組件返回一個與Redux store
// 關聯(lián)起來的新組件
const ConnectedComment = enhance(Component);        

antd的Form也是一樣的

const WrappedNormalLoginForm = Form.create()(NormalLoginForm);   

總結一下: 高階組件是對React代碼進行更高層次重構的好方法,如果你想精簡你的state和生命周期方法,那么高階組件可以幫助你提取出可重用的函數(shù)。一般來說高階組件能完成的用組件嵌套+繼承也可以,用嵌套+繼承的方式理解起來其實更容易一點,特別是去重構一個復雜的組件時,通過這種方式往往更快,拆分起來更容易。至于到底用哪個最佳還要具體看業(yè)務場景,歡迎交流探討

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/116101.html

相關文章

  • 更快助你弄懂React-高階組件

    摘要:等價于是一個返回函數(shù)的函數(shù)就是個高階函數(shù)返回的函數(shù)就是一個高階組件,該高階組件返回一個與關聯(lián)起來的新組件的也是一樣的總結一下高階組件是對代碼進行更高層次重構的好方法,如果你想精簡你的和生命周期方法,那么高階組件可以幫助你提取出可重用的函數(shù)。 談到react,我們第一個想到的應該是組件,在react的眼中可真的是萬物皆組件。就連我們獲取數(shù)據(jù)用到的axios也可以用組件來表示...比如,我...

    qylost 評論0 收藏0
  • 更快助你弄懂React-高階組件

    摘要:等價于是一個返回函數(shù)的函數(shù)就是個高階函數(shù)返回的函數(shù)就是一個高階組件,該高階組件返回一個與關聯(lián)起來的新組件的也是一樣的總結一下高階組件是對代碼進行更高層次重構的好方法,如果你想精簡你的和生命周期方法,那么高階組件可以幫助你提取出可重用的函數(shù)。 談到react,我們第一個想到的應該是組件,在react的眼中可真的是萬物皆組件。就連我們獲取數(shù)據(jù)用到的axios也可以用組件來表示...比如,我...

    libxd 評論0 收藏0
  • 更快助你弄懂React-高階組件

    摘要:等價于是一個返回函數(shù)的函數(shù)就是個高階函數(shù)返回的函數(shù)就是一個高階組件,該高階組件返回一個與關聯(lián)起來的新組件的也是一樣的總結一下高階組件是對代碼進行更高層次重構的好方法,如果你想精簡你的和生命周期方法,那么高階組件可以幫助你提取出可重用的函數(shù)。 談到react,我們第一個想到的應該是組件,在react的眼中可真的是萬物皆組件。就連我們獲取數(shù)據(jù)用到的axios也可以用組件來表示...比如,我...

    xushaojieaaa 評論0 收藏0
  • 更快助你弄懂React-高階組件

    摘要:等價于是一個返回函數(shù)的函數(shù)就是個高階函數(shù)返回的函數(shù)就是一個高階組件,該高階組件返回一個與關聯(lián)起來的新組件的也是一樣的總結一下高階組件是對代碼進行更高層次重構的好方法,如果你想精簡你的和生命周期方法,那么高階組件可以幫助你提取出可重用的函數(shù)。 談到react,我們第一個想到的應該是組件,在react的眼中可真的是萬物皆組件。就連我們獲取數(shù)據(jù)用到的axios也可以用組件來表示...比如,我...

    Keven 評論0 收藏0
  • React 深入系列6:高階組件

    摘要:在項目中用好高階組件,可以顯著提高代碼質量。高階組件的定義類比于高階函數(shù)的定義。高階函數(shù)接收函數(shù)作為參數(shù),并且返回值也是一個函數(shù)。 React 深入系列,深入講解了React中的重點概念、特性和模式等,旨在幫助大家加深對React的理解,以及在項目中更加靈活地使用React。 1. 基本概念 高階組件是React 中一個很重要且比較復雜的概念,高階組件在很多第三方庫(如Redux)中都...

    2shou 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<