亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

React中高階組件如何使用

發布時間:2020-11-10 11:18:39 來源:億速云 閱讀:171 作者:小新 欄目:web開發

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

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中高階組件如何使用有了一定的了解,想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

长白| 兴义市| 兴宁市| 长汀县| 濉溪县| 孟连| 垣曲县| 含山县| 郎溪县| 麦盖提县| 山阳县| 达孜县| 保康县| 玉环县| 卫辉市| 开化县| 张掖市| 文成县| 康乐县| 汶川县| 马山县| 新乐市| 镇平县| 左权县| 天峨县| 德钦县| 蚌埠市| 中西区| 读书| 什邡市| 兴安县| 康马县| 河池市| 资阳市| 郴州市| 三明市| 沂南县| 辽阳县| 保定市| 梨树县| 汉中市|