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

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è)公司
亚洲淫婷婷久久一区二区| 亚洲国产日朝欧美综合久久| 亚洲字幕中文在线乱码mv| 国产日韩精品一区二区在线| 欧美女人又粗又长亚洲| 黑人精品少妇一区二区三区| 久久国产综合精品电影| 国产精品日韩经典中文字幕| 日韩不卡在线观看免费| 国产又粗又长在线视频| 国产一区999精品在线| 国产日韩精品综合一区| 麻豆人妻一区二区三区| 草草影院最新地址在线观看| 在线视频天堂亚洲天堂| 国产精品无遮挡猛进猛出 | 婷婷色精品一区二区激情| 国产b片免费在线观看| 国产精品自拍小视频91| 国产男女免费完整视频| 91人妻成人精品一区二区| 欧美激情在线精品一区二区| 久久99热这里只频精品| 亚洲欧美日韩不卡视频| 亚洲av男人电影天堂| 国产老太婆精品久久久久| 国产视频专区一区二区| 亚洲成人精品夫妻av| 成人黄色av网站在线观看| 亚洲天堂av成人在线观看| 久久精品国产亚洲av麻豆她| 国产精品一区二区在线观看| 中文字幕av免费专区| 青青草免费在线视频视频| 中文字幕国产精品经典三级 | 国产传媒剧情剧资源网站| 日本免费91午夜视频| 国产九色91中文在线视频| 禁区正片免费看完整国产| 一区二区三区熟妇人妻视频| 日韩中文字幕综合不卡|