ホームページ >ウェブフロントエンド >jsチュートリアル >React の高次コンポーネントの簡単な説明

React の高次コンポーネントの簡単な説明

亚连
亚连オリジナル
2018-05-28 16:42:431606ブラウズ

この記事では主に React の高次コンポーネントについて簡単に説明しますので、参考にしてください。

少し前に仕事でハイブリッド ページを作成していたときに、このようなシナリオに遭遇しました。会社には一連のアクティブなコンポーネントが必要で、各コンポーネントを登録するときにアプリが提供するインターフェイスを呼び出す必要があります。当初は、ミックスイン、コンポーネントの継承、高次コンポーネントの反応など、いくつかの方法が検討されました。しかし、さまざまな検討を行った結果、最終的には高レベルのコンポーネントを使用することを選択しました。

それでは、高度なコンポーネントとは何ですか?まず、ES6 でのクラスのリクエストは単なる構文上の糖衣であり、本質はプロトタイプの継承であることを理解する必要があります。これをわかりやすく説明するために、コンポーネントのコードは変更しません。代わりに、コンポーネントをラップし、追加機能でコンポーネントを強化するコンポーネントが提供されます。このような成分を高次成分(Higher-Order Component)と呼びます。

1. Mixins の欠点

React は、コードの再利用を実現するために Mixins テクノロジーの使用を公式に推奨していません。 まず、Mixins は次の方法で名前の競合を引き起こします。

var myMixins = require('myMixins');

var Button = React.createClass({
  mixins: [myMixins],
  
  // ...
})

複数のミックスインを挿入する必要がある場合、そのうちの 1 つは自分のもので、もう 1 つはサードパーティのものである可能性があります。 2 つのミックスインで同じ名前のメソッドを使用すると、一方が機能しなくなる可能性があり、できることは一方のメソッドの名前を変更することだけです。一方、ミックスインは最初は特定の機能を実装するだけで非常にシンプルですが、ビジネスがより複雑になり、より多くのメソッドを追加する必要があると、非常に複雑になります。ミックスインの欠点について詳しくは、公式ブログをご覧ください。

2. コンポーネントの継承

まず、BaseComponent を作成し、その中に一連の public メソッドを実装します。ただし、欠点は、このコンポーネントから継承されることです。基本的なコンポーネントにはいくつかの比較的固定されたメソッドしか実装できず、各コンポーネントのカスタマイズには大きな制限があります。

3. React の高次コンポーネント

ミックスインの一連の欠点により、React 関係者は、ミックスインの使用によって引き起こされる問題点がテクノロジー自体の利点よりもはるかに大きいことにも気づきました。ミックスインを置き換えることができ、さらに深く掘り下げると、さらに豊富な用途があります。

高次コンポーネント (HOC) は、コンポーネント ロジックを再利用する React の高度なテクノロジーです。ただし、高次コンポーネント自体は React API ではありません。これは、React 自体の構成上の性質から必然的に生じるパターンにすぎません。

高階関数

高階コンポーネントと言えば、まず高階関数について説明する必要があります。少なくとも次の条件を満たす関数です:

1.関数を入力として使用します
2. 関数を出力します

関数が第一級市民である言語である JavaScript では、通常のコールバック関数などの高階関数が依然として多く使用されています。高次関数の知識。まずは簡単な高階関数を見てみましょう

var fun = function(x, y) {
  return x + y;
}

funは関数です。 次に、関数全体をパラメータとして別の関数に渡します

var comp = function(x, y, f) {
  return f(x,y);
}

それを確認してください

comp(1,2,fun) // 3

高階コンポーネントの定義

高階関数の定義と同様に、高階コンポーネントはコンポーネントをパラメータとして受け取り、関数内のコンポーネントに対して一連の処理を実行し、新しいコンポーネントを返します。コンポーネントを戻り値として返します。

最初に上位コンポーネントBaseActivityを定義します

const BaseActivity = (WrappedComponent) => {
 return class extends Component {
  render() {
   return (
    <section>
     <p>我的包裹组件</p>
     <WrappedComponent />
    </section>
    
   )
  }
 }
}

このコンポーネントはラップされたコンポーネントをパラメータとして受け取り、処理された匿名コンポーネントを返します。

この上位コンポーネントを他のコンポーネントで使用します

class Example extends React.PureComponent {
 constructor(props) {
  super(props);
  this.state = {
   width: &#39;100%&#39;,
   height: &#39;100%&#39;
  }
 }

 componentWillMount() {
  if ((navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i))) {
   return;
  } else {
   this.setState({
    width: &#39;375px&#39;,
    height: &#39;640px&#39;
   })
  }
 }

 render() {
  let { width, height } = this.state;
  return (
   <p className="activity">
    <p className="activity-content" style={{ width, height }}>
     <button className="btn">参加活动</button>
    </p>
   </p>
  )
 }
}

export default BaseActivity(Example);

具体的な使用方法は、コンポーネントをエクスポートするときに BaseActivity 関数を使用してこのコンポーネントをラップし、出力の反応 dom コンテンツを確認することです


Example コンポーネントは匿名コンポーネントでラップされています。

パラメータ

上位コンポーネントは関数なので、必要なパラメータをそれに渡すことができます

const BaseActivity = (WrappedComponent, title) => {
 return class extends Component {
  render() {
   return (
    <section>
     <p>{title}</p>
     <WrappedComponent />
    </section>
    
   )
  }
 }
}

例ではこのようにエクスポートします

export default BaseActivity(Example, &#39;这是高阶组件的参数&#39;);

見てみましょう出力は dom


に反応し、パラメーターが渡されたことがわかります。

もちろん、このように使うこともできます(カリー化)

const BaseActivity (title) => (WrappedComponent) => {
 return class extends Component {
  render() {
   return (
    <section>
     <p>{title}</p>
     <WrappedComponent />
    </section>
    
   )
  }
 }
}

例ではこのようにエクスポートします

export default BaseActivity(&#39;这是高阶组件的参数&#39;)(Example);

この使用法は、ant-designとreduxのconnectの形で見ることができます

// ant
const WrappedDemo = Form.create()(Demo)

// redux
export default connect(mapStateToProps, mapDispatchToProps)(Counter)

以下に示すように、高次コンポーネントは元のコンポーネントの props 属性を拡張することもできます:

const BaseActivity (title) => (WrappedComponent) => {
 return class extends Component {
  render() {
   const newProps = {
     id: Math.random().toString(8)
   }
   return (
    <section>
     <p>{title}</p>
     <WrappedComponent {...this.props} {...newProps}/>
    </section>
   )
  }
 }
}

出力を見てください。


高階コンポーネントの欠点

高次コンポーネントにも一連の欠点があります。 1 つ目は、コンポーネントを渡すことです。を関数にパラメータとして追加すると、返されるのは元のコンポーネントではなく新しいコンポーネントになり、元の静的メソッドは当然存在しなくなります。保持する必要がある場合は、元のコンポーネントのメソッドを新しいコンポーネントに手動でコピーするか、hoist-non-react-statics などのライブラリを使用してコピーします。

上記は私があなたのためにまとめたものです。

関連記事:

応答コンテンツの長さを取得するAjaxメソッド

ページ上の特定のコンテンツの定期的な更新を実装するAjaxメソッド

プロパティリソースファイルデータを読み取るAjaxメソッド

以上がReact の高次コンポーネントの簡単な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。