React中高階組件如何使用

小編給大家分享一下React中高階組件如何使用,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

創新互聯-專業網站定制、快速模板網站建設、高性價比豐順網站開發、企業建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式豐順網站制作公司更省心,省錢,快速模板網站建設找我們,業務覆蓋豐順地區。費用合理售后完善,10余年實體公司更值得信賴。

Higher-Order Components

  • HOC 不是React的標準API。

  • HOC 是一個函數。

  • HOC 返回一個Component

示例:

const EnhancedComponent = higherOrderComponent(WrappedComponent);

使用場景

代碼復用

類似React 0.15版本之前的mixin。

多個組件同用一段代碼,或者同樣的方法時,可以使用HOC。

示例:

import React, { PureComponent } from 'react';

const Common = (WrapComponent) => {
  return (
    <div>
      <h2>Title</h2>
      <WrapComponent />
    </div>
  );
};

const Header = () => <div>Header</div>;
const Footer = () => <div>Footer</div>;

export default class extends PureComponent {
  render() {
    return (
      <div>
        <div>
          <p>Header Component</p>
          {Common(Header)}
        </div>
        <hr />
        <div>
          <p>Footer Component</p>
          {Common(Footer)}
        </div>
      </div>
    );
  }
}

在線示例

抽象state和更改props

可以通過WrappedComponent包裹的組件公共state抽象出來。

可以通過WrappedComponent包裹的組件傳遞修改、添加等的props.

示例:

const HOComp = (WrappedComponent) => {
  return class extends React.Component {
    constructor(props) {
      super(props);
      this.state = {name: ''};
    }

    componentDidMount() {
      this.setState({name: WrappedComponent.displayName || WrappedComponent.name || 'Component';});
    }

    return <WrappedComponent name={this.state.name} {...this.props}/>
  }
}

渲然劫持

條件渲然。根據props或者state條件返回在渲然的內容。

示例:

const HOComp = (WrappedComponent) => {
  return class Enhancer extends WrappedComponent {
    render() {
      if (this.props.loggedIn) {
        return super.render()
      } else {
        return null
      }
    }
  }
}

反向繼承

返回的高階組件類(Enhancer)繼承了 WrappedComponent。

示例:

const EnchanceComponent = (WrappedCompopnent) => {
  return class extends WrappedCompopnent {
    constructor(props) {
      super(props);
      this.state = { error: '' };
    }
    componentDidMount() {
      /*do something*/
      super.componentDidMount();
    }
    render() {
      if (this.state.error) {
        return <p>{this.state.error}</p>;
      } else {
        return super.render();
      }
    }
  }
};

看完了這篇文章,相信你對React中高階組件如何使用有了一定的了解,想了解更多相關知識,歡迎關注創新互聯行業資訊頻道,感謝各位的閱讀!

名稱欄目:React中高階組件如何使用
分享鏈接:http://m.kartarina.com/article34/pphpse.html

成都網站建設公司_創新互聯,為您提供自適應網站品牌網站建設商城網站做網站網站內鏈品牌網站制作

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都網站建設公司
主站蜘蛛池模板: 亚洲AV无码乱码国产麻豆| 久久国产精品无码一区二区三区 | 精品国产一区二区三区无码| 亚洲中文字幕不卡无码| 亚洲?V无码成人精品区日韩| 免费无码又爽又刺激一高潮| 免费无码一区二区三区| 精品久久亚洲中文无码| 亚洲av中文无码字幕色不卡| 亚洲欧洲日产国码无码网站 | 中文无码vs无码人妻| 久久亚洲AV永久无码精品| 亚洲美免无码中文字幕在线| 无码人妻精品一区二区蜜桃 | 亚洲久热无码av中文字幕 | 久久久久久国产精品免费无码 | 无码av高潮喷水无码专区线| 无码色偷偷亚洲国内自拍| 日本无码WWW在线视频观看| 亚洲AV无码片一区二区三区| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 日日摸日日踫夜夜爽无码| aⅴ一区二区三区无卡无码| 国产aⅴ无码专区亚洲av| 日韩AV无码精品一二三区| 亚洲国产成人精品无码区在线秒播| 国产精品无码av片在线观看播| 中文无码喷潮在线播放| 97人妻无码一区二区精品免费| 精品久久久久久无码中文字幕| 亚洲色无码国产精品网站可下载| 久久青青草原亚洲av无码| 无码熟妇人妻AV在线影院| 久久久久无码精品国产| 亚洲精品无码乱码成人| 国产在线无码精品电影网| 无码人妻品一区二区三区精99| 无码午夜成人1000部免费视频| 国产a v无码专区亚洲av| 免费无码又爽又刺激高潮| 亚洲中文字幕不卡无码|