ホームページ > ウェブフロントエンド > jsチュートリアル > React で親コンポーネントから子メソッドを呼び出すにはどうすればよいですか?

React で親コンポーネントから子メソッドを呼び出すにはどうすればよいですか?

Linda Hamilton
リリース: 2024-12-25 13:16:10
オリジナル
1027 人が閲覧しました

How Can I Call Child Methods from Parent Components in React?

親コンポーネントから子メソッドを呼び出す

React では、子メソッドを直接呼び出す必要は必ずしもありません。ただし、子コンポーネントが命令型メソッドを公開する場合など、必要になる場合もあります。この記事では、クラスベースのコンポーネントと関数型コンポーネントの両方で、refs を使用してこれを実現する方法を説明します。

クラスベースのコンポーネント

refs を使用して親クラスベースのコンポーネントから子メソッドを呼び出すには、次のようにします。次の手順に従ってください:

  1. 次を使用して親コンポーネントに ref を作成します。 createRef():
const childRef = React.createRef();
ログイン後にコピー
  1. 子コンポーネントに参照を割り当てます:
<Child ref={childRef} />
ログイン後にコピー
  1. childRef を使用して子のメソッドにアクセスします:
childRef.current.getAlert();
ログイン後にコピー
ログイン後にコピー

機能コンポーネントフック

React Hooks の導入により、関数コンポーネントでも refs を使用できるようになりました。 refs を使用して親機能コンポーネントから子メソッドを呼び出す方法は次のとおりです:

  1. useRef() フックを使用して ref を作成します:
const childRef = useRef();
ログイン後にコピー
  1. 子コンポーネントを forwardRef でラップして、 ref:
const Child = forwardRef((props, ref) => {
  // ...
});
ログイン後にコピー
  1. useImperativeHandle フックを使用して、子のメソッドを親に公開します:
useImperativeHandle(ref, () => ({ getAlert() { alert('clicked'); } }));
ログイン後にコピー
  1. childRef を使用してアクセスします子供のメソッド:
childRef.current.getAlert();
ログイン後にコピー
ログイン後にコピー

注: React では、refs を使用して子メソッドを呼び出すことは一般に推奨されていないことに注意することが重要です。データを下に渡し、イベントを props と state を通じて上に渡すことをお勧めします。

以上がReact で親コンポーネントから子メソッドを呼び出すにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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