91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

准格尔旗| 吉安市| 台东县| 侯马市| 铜山县| 应用必备| 长治市| 奉新县| 旬阳县| 临泽县| 成都市| 玉山县| 永兴县| 梓潼县| 济南市| 昌乐县| 庆云县| 娱乐| 珠海市| 吉木萨尔县| 乐山市| 玉龙| 广平县| 阜城县| 巴彦县| 定襄县| 客服| 房产| 涪陵区| 永仁县| 眉山市| 莱西市| 岳西县| 梧州市| 龙江县| 高淳县| 安顺市| 潮州市| 清新县| 望江县| 水城县|