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

資訊專欄INFORMATION COLUMN

七進七出React高階組件

miguel.jiang / 2649人閱讀

摘要:為了提高代碼的復用性和可維護性,高階函數應運而生。使用過的同學,不知道有沒有使用過,高階函數的作用和它是一樣的。高階函數在編程中扮演的角色就是火鍋鍋底的角色,它有公用的方法和屬性,而各種組件就是肉和蔬菜。

為什么要使用高階組件?

想想以前用原生和jQuery的項目,上千行的code映入眼簾,瞬間有種昏死過去的沖動。代碼難以維護,改一個bug可能出現N個bug,真的是很痛苦。于是乎組件化成為了當前前端開發(fā)的主流技術。angular、vue和react很好的幫我們實現了組件化。

但是我們常常也會遇到一種情況,就是兩個組件往往有很多的重復代碼(可能是相同的屬性,也可能是相同的方法)。例如,在登錄和注冊組件中,都會有用戶名和密碼,以及對他們的校驗規(guī)則。為了提高代碼的復用性和可維護性,React高階函數應運而生。

React之前對此的解決方案是mixin,但這造成和很多不必要的問題,后來就被廢棄掉了。使用過vue的同學,不知道有沒有使用過mixin,react高階函數的作用和它是一樣的。

高階組件到底是個什么東西?

高階組件其實是一個函數,它并不是一個組件,我們需要向它傳遞一些參數(想要操作的組件、屬性)。這么說起來它其實一點也不高階,它的作用就是存儲一些公共的屬性和方法。

我們經常幾個人吃過一個鍋底的那種火鍋,鍋底里有火鍋底料和各種佐料,我們把肉和蔬菜等放進去涮一下,就可以美美的飽餐一頓。高階函數在react編程中扮演的角色就是火鍋鍋底的角色,它有公用的方法和屬性,而各種組件就是肉和蔬菜。如果是一個人一個鍋的火鍋就像沒有經過封裝的code,代碼量重復且維護困難。

如何實現高階函數?

我們先來看一段可以使用高階函數的代碼:

這里有一個Second組件,它負責展示用戶名username

export class Second extends React.Component {
    constructor(props) {
        super(props);
        this.state = {
            username: ""
        }
    }
    componentWillMount() {
        let username = localStorage.getItem("username");
        this.setState({
            username: username
        });
    }
    render() {
        return(
            
Second Page

Hi {this.state.username}

) } }

下面是一個Third組件,它也負責展示用戶名

export class Third extends React.Component {
    constructor(props) {
        super(props);
        this.state = {
            username: ""
        }
    }
    componentWillMount() {
        let username = localStorage.getItem("username");
        this.setState({
            username: username
        });
    }
    render() {
        return(
            
Third Page

Hi {this.state.username}

我今年18歲了

) } }

我們看到這兩個組件除了名稱以外,其余大量的代碼是一樣的,我們完全可以考慮將它們通用的代碼提取出來。下面就是高階組件出場的時候了。

高階組件可以寫成這樣

export const HighOrderComponent = (WrapComponent, title) => {
    return class HOC extends React.Component {
        constructor(props) {
            super(props);
            this.state = {
                username: ""
            }
        }
        componentWillMount() {
            let username = localStorage.getItem("username");
            this.setState({
                username: username
            });
        }
        static displayName = `HOC(${getDisplayName(WrapComponent)})`;
        render() {
            return(
                
{title}
) } } }

WrapComponent 是我們要操作的組件

title 是它們的標題參數

username 就是我們常用的props,它負責向組件傳遞值,我們下面還會提到

使用高階組件之后我們要對Second和Third組件進行修改,修改如下

class Second extends React.Component {
    render() {
        return(
            

Hi {this.props.username}

曉不曉得哪里好耍

) } } export const HighOrderSecond = HighOrderComponent(Second, "Second Page");
class Third extends React.Component {

    render() {
        return(
            

Hi {this.props.username}

) } } export const HighOrderThird = HighOrderComponent(Third, "Third Page");

很多同學可能會問,export出去的常量是干什么用的,它就是高階組件對組件進行封裝之后的一個全新的組件,是兩者的結合。到此,我們在其它頁面引用組件就不再是引用Second和Third組件了,要引用的就是HighOrderSecond和HighOrderThird了。

細心的同學可能會發(fā)現一些不同的地方,對于Second和Third的公共legend提取出去了,但并沒有將h2對應得標題提取出去,這里只是想給大家說一下,在對組件使用高階組件包裹之后,高階組件就變成了組件的父組件,它的state可以通過props的方式向子組件傳遞,username就是這樣。我們在chrome的react插件中可以觀察到這一點

HOC已經將Second組件包裹起來,成為了它的父組件,它上面的match和location是我使用了react-router的緣故,我們可以不用去管它。它的state——username作為props傳給了Second


今天給大家簡單的介紹了React高階組件的一些知識,后續(xù)還會再深入的挖掘React高階組件的知識和大家分享,希望對大家有幫助。文章轉自個人掘金賬號,轉載請注明出處,謝謝

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

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

相關文章

  • React 深入系列6:高階組件

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

    2shou 評論0 收藏0
  • 深入淺出React高階組件

    摘要:博客地址背景知識在開始講述高階組件前,我們先來回顧高階函數的定義接收函數作為輸入,或者輸出另一個函數的一類函數,被稱作高階函數。 博客地址:http://www.luckyjing.com/post... 背景知識 在開始講述高階組件前,我們先來回顧高階函數的定義:接收函數作為輸入,或者輸出另一個函數的一類函數,被稱作高階函數。對于高階組件,它描述的便是接受React組件作為輸入,輸出...

    yuanzhanghu 評論0 收藏0
  • React高階組件

    摘要:結語高階函數對于初學者來說可能不太好理解,但當你深入其中,了解其中的原理之后,我們可以使用高階函數來完成很多的工作。 前段時間在工作中寫Hybrid頁面時遇到了這樣的一個場景,公司需要一系列的活動組件,在每個組件注冊的時候都需要調用App端提供的一個接口。一開始也考慮了幾種方式,包括mixin、組件繼承以及react高階組件。但經過了種種衡量,最后選擇使用了高階組件的做法。 1、Mix...

    ThinkSNS 評論0 收藏0
  • 從零開始學習 React 高階組件

    01、介紹 React 高階組件也叫做 React HOC(High Order Component), 它是react中的高級技術, 用來重用組件邏輯。 但高階組件本身并不是React API。它只是一種模式,這種模式是由react自身的組合性質必然產生的。 那么在學習高階組件之前有一個概念我們必須清楚,就是高階函數。 02、高階函數 概念:高階函數是一個函數,它接收函數作為參數或將函數作...

    _Dreams 評論0 收藏0
  • React高階組件

    摘要:高階組件高階函數接收函數作為輸入,或者輸出另一個函數的一類函數高階組件接收組件作為輸入,輸出一個新的組件的組件。包含了一系列實用的高階組件庫拖動庫深入理解高階組件其中詳細介紹了屬性代理和反向繼承的區(qū)別。 React高階組件 高階函數: 接收函數作為輸入,或者輸出另一個函數的一類函數; 高階組件: 接收React組件作為輸入,輸出一個新的React組件的組件。 高階組件通過包裹一個新傳入...

    cncoder 評論0 收藏0

發(fā)表評論

0條評論

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