ホームページ > ウェブフロントエンド > jsチュートリアル > React Router でハンドルされたコンポーネントに Props を渡すにはどうすればよいですか?

React Router でハンドルされたコンポーネントに Props を渡すにはどうすればよいですか?

Patricia Arquette
リリース: 2024-10-24 00:02:02
オリジナル
265 人が閲覧しました

How to Pass Props to Handled Components in React Router?

React Router でハンドルされるコンポーネントに props を渡す

React Router を使用する React.js アプリケーションでは、ハンドルされるコンポーネントに props を渡す必要があることがよくあります。これを実現するには、考慮すべきアプローチがいくつかあります。

1 つの簡単なアプローチは、必要な props を取得し、必要に応じてそれらを渡す新しいコンポーネントでハンドルされたコンポーネントをラップすることです。

<code class="javascript">var CommentsWrapper = React.createClass({
  render: function () {
    return <Comments myprop="value" />;
  }
});</code>
ログイン後にコピー

このようにして、CommentsWrapper を目的のルートのハンドラーとして使用できます:

<code class="javascript">var routes = (
  <Route path="/" handler={Index}>
    <Route path="comments" handler={CommentsWrapper}/>
    <DefaultRoute handler={Dashboard}/>
  </Route>
);</code>
ログイン後にコピー

ただし、このアプローチは、処理される複数のコンポーネントに props を渡す必要がある場合に扱いにくくなる可能性があります。このような場合、より柔軟なアプローチは、ルート設定でコンポーネント プロパティを使用することです。これにより、処理されるコンポーネントに props を直接渡すことができます。

<code class="javascript">var routes = (
  <Route path="/" component={Index}/>
);

var Index = React.createClass({
  render: function () {
    return (
      <div>
        <header>Some header</header>
        <RouteHandler myprop="value" />
      </div>
    );
  }
});</code>
ログイン後にコピー

このアプローチでは、props を直接次のコンポーネントに渡すことができます。ラッパーを必要としないコメントコンポーネント:

<code class="javascript"><Route path="comments" component={Comments}/></code>
ログイン後にコピー

以上がReact Router でハンドルされたコンポーネントに Props を渡すにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート