欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

React中高階組件如何使用

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

創(chuàng)新互聯(lián)-專(zhuān)業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性?xún)r(jià)比豐順網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式豐順網(wǎng)站制作公司更省心,省錢(qián),快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋豐順地區(qū)。費(fèi)用合理售后完善,10余年實(shí)體公司更值得信賴(lài)。

Higher-Order Components

  • HOC 不是React的標(biāo)準(zhǔn)API。

  • HOC 是一個(gè)函數(shù)。

  • HOC 返回一個(gè)Component。

示例:

const EnhancedComponent = higherOrderComponent(WrappedComponent);

使用場(chǎng)景

代碼復(fù)用

類(lèi)似React 0.15版本之前的mixin。

多個(gè)組件同用一段代碼,或者同樣的方法時(shí),可以使用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

可以通過(guò)WrappedComponent包裹的組件公共state抽象出來(lái)。

可以通過(guò)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}/>
  }
}

渲然劫持

條件渲然。根據(jù)props或者state條件返回在渲然的內(nèi)容。

示例:

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

反向繼承

返回的高階組件類(lèi)(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();
      }
    }
  }
};

看完了這篇文章,相信你對(duì)React中高階組件如何使用有了一定的了解,想了解更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

名稱(chēng)欄目:React中高階組件如何使用
分享鏈接:http://aaarwkj.com/article34/pphpse.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站、品牌網(wǎng)站建設(shè)商城網(wǎng)站、做網(wǎng)站、網(wǎng)站內(nèi)鏈品牌網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司
97精品久久九九中文字幕| 亚洲av永久精品一区二区三区| 亚洲男人的天堂社区av| 日本丰满熟女毛茸茸的黑逼| 亚洲av丰满熟妇在线观看| 亚洲精品乱码精品乱码不卡| 欧美日韩国产综合精品亚洲| 亚洲欧美国产精品久久久| 夫妻性生活视频全过程| 在线视频一区二区三区精品观看| 国产成人啪精品视频免费| 亚洲精品国产熟女高潮| 国产三级在线播放完整| 女人的天堂av免费在线观看| 久久人妻一区二区三区免费| 日韩成人在线视频中文字幕| 国产高清剧情在线观看| 少妇人妻精品一区二区三| 久久99久久精品视频国产| 五月婷婷综合中文字幕在线| 国产亚洲日本一区二区三区| 微拍福利一区二区三区| 日韩免费黄色av网站| 一级黄片一区二区三区| 免费观看在线视频午夜| 欧美国内日本一区二区| 国产美女口爆吞精久久| 亚洲伊人av第一页在线观看 | 国产精品国产三级丝袜| 国产av高清视频在线| 日韩精品视频在线观看| 正在播放老肥熟妇露脸| 在线观看免费国产不卡| 好吊视频在线免费观看| 亚洲自偷精品视频自拍| 亚洲国产精品日韩专区av有中文 | 日本不卡一区二区在线观看| 在线播放欧美视频91| 色日韩在线观看视频| 欧美内射专区精品一区| 欧美一区二区成人精品视频|