「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > React フックとイベント リスナーを使用すると、ステート コンソール ログに間違った情報が表示されるのはなぜですか?

React フックとイベント リスナーを使用すると、ステート コンソール ログに間違った情報が表示されるのはなぜですか?

2024 年 11 月 7 日に公開
ブラウズ:647

When Using React Hooks and Event Listeners, Why Does the State Console Log Display Incorrect Information?

イベント リスナーと React フック

問題: React フックとイベント リスナーを使用すると、状態コンソール ログに誤った情報が表示されます。

問題の説明

提供されている CodeSandbox: https://codesandbox.io/s/lrxw1wr97m を考えてみましょう。 [カードの追加] ボタンを 2 回クリックし、最初のカードの [ボタン 1] をクリックすると、コンソールには 2 枚のカードがある状態が正しく表示されます。ただし、同じカード (イベント リスナーによって処理される) の「Button2」をクリックすると、コンソールにはその状態のカードが 1 枚だけ誤って表示されます。

状態が正しくない理由

この問題は、CardsProvider コンポーネントと Card コンポーネントでのイベント ハンドラーの処理が異なるために発生します。 CardsProvider 機能コンポーネント内で定義されたイベント ハンドラー、handleCardClick および handleButtonClick は、コンポーネントがレンダリングされるたびに再定義されます。これは、定義された時点の状態を参照することを意味します。イベント リスナーがトリガーされると、この状態は失効する可能性があります。

一方、Card コンポーネントは useRef を使用してイベント リスナーを登録します。イベント リスナーは永続化されます。コンポーネントのライフサイクル全体にわたって。その結果、イベント リスナー関数は、コンポーネントがマウントされた時点の状態を参照し、古い状態になります。

解決策 - 状態アップデーター機能を使用する

1 つの解決策は、状態アップデーターを使用することです。囲んでいるスコープからの古い状態に依存するのではなく、引数として新しい状態を受け取る関数:

const eventListener = () => {
  // Function receives fresh state
  setState(freshState => freshState   1);
};

// Event listener is registered using `useEffect` to ensure it is only registered once
useEffect(() => {
  // Register event listener
  // ...

  // Unregister event listener on component unmount
  return () => {
    // ...
  };
}, []);

このシナリオでは、イベント リスナーは新しい状態を受け取るため、古いデータの問題は解消されます。ただし、状態アップデータ関数は不要な更新を防ぐために同じ状態を返すことができることに注意することが重要です。状態アップデータ関数内で console.log を使用して、状態の変化を観察します。

その他の解決策

この問題に対処する別の方法には次のようなものがあります:

  • Mutable State: useState の代わりに useRef を使用します。
  • 手動イベント リスナー再登録: 状態が変化するたびにイベント リスナーを再登録します。
  • 組み込みイベント処理: カスタム イベント リスナーではなく、React の組み込みイベント処理を使用します。
リリースステートメント この記事は次の場所に転載されています: 1729253539 権利侵害がある場合は、[email protected] に連絡して削除してください。
最新のチュートリアル もっと>
  • パスキーを Java Spring Boot に統合する方法
    パスキーを Java Spring Boot に統合する方法
    Java Spring Boot のパスキーの概要 パスキーは、従来のパスワードに依存せずにユーザーを認証する最新の安全な方法を提供します。このガイドでは、Thymeleaf をテンプレート エンジンとして使用して、Java Spring Boot アプリケーションにパスキーを統合...
    プログラミング 2024 年 11 月 7 日に公開
  • グアテマラの前環境大臣としてのマリオ・ロベルト・ロハス・エスピノの影響
    グアテマラの前環境大臣としてのマリオ・ロベルト・ロハス・エスピノの影響
    マリオ・ロベルト・ロハス・エスピノはグアテマラの元環境大臣として、国の持続可能な発展に貢献した環境政策の実施において重要な役割を果たしました。同省長官としての彼の経営は、特に環境立法や保全プロジェクトの面で重要な遺産を残した。この記事では、彼の影響力と、任期中に彼が推進した主な政策について探ります。...
    プログラミング 2024 年 11 月 7 日に公開
  • データ収集のためにクラスのすべてのインスタンスを追跡してアクセスするにはどうすればよいですか?
    データ収集のためにクラスのすべてのインスタンスを追跡してアクセスするにはどうすればよいですか?
    データ収集のためのクラス インスタンスの追跡プログラムの終わりに近づいており、複数の変数から特定の変数を抽出する必要があると想像してください。クラスのインスタンスを使用して辞書を作成します。このタスクは、集約または分析する必要がある重要なデータを保持するオブジェクトを操作するときに発生することがあり...
    プログラミング 2024 年 11 月 7 日に公開
  • PHP 連想配列内で検索する方法 – 簡単なヒント
    PHP 連想配列内で検索する方法 – 簡単なヒント
    連想配列は PHP の基本的なデータ構造であり、開発者はキーと値のペアを保存できます。これらは多用途であり、構造化データを表すためによく使用されます。 PHP 連想配列内の特定の要素を検索するのは一般的なタスクです。ただし、PHP で使用できるほとんどのネイティブ関数は、単純な配列でもうまく機能しま...
    プログラミング 2024 年 11 月 7 日に公開
  • Web 開発の未来: すべての開発者が知っておくべき新たなトレンドとテクノロジー
    Web 開発の未来: すべての開発者が知っておくべき新たなトレンドとテクノロジー
    導入 Web 開発は、初期の静的な HTML ページとシンプルな CSS デザインから大きく進歩しました。技術の進歩と、よりダイナミックでインタラクティブで応答性の高い Web サイトに対するユーザーの需要の高まりにより、この分野は長年にわたって急速に進化してきました。インターネッ...
    プログラミング 2024 年 11 月 7 日に公開
  • ays 初心者の Python コード者は ChatGPT を使用できます
    ays 初心者の Python コード者は ChatGPT を使用できます
    初心者の Python 開発者は、きれいなコードの作成からエラーのトラブルシューティングまで、数え切れないほどの課題に直面します。 ChatGPT は、生産性を向上させ、コーディング作業を合理化するための秘密兵器となります。際限なくドキュメントやフォーラムを調べる代わりに、ChatGPT に直接質...
    プログラミング 2024 年 11 月 7 日に公開
  • システムに Deno をインストールする
    システムに Deno をインストールする
    ? Windows への Deno のインストール: クイックガイド やあ、皆さん! ? Deno に飛び込む準備はできましたか?この素晴らしいランタイムを Windows マシンにインストールして始めましょう。とても簡単ですので、ステップバイステップでご案内します! ...
    プログラミング 2024 年 11 月 7 日に公開
  • Mac OS X で複数の Java バージョンを効果的に管理するにはどうすればよいですか?
    Mac OS X で複数の Java バージョンを効果的に管理するにはどうすればよいですか?
    Mac OS X での複数の Java バージョンの管理Mac OS X で開発する場合、互換性要件が異なるさまざまなプロジェクトに複数の Java バージョンが必要になる場合があります。この記事では、Mac に複数の Java バージョンを効果的にインストールして管理する方法について説明します。H...
    プログラミング 2024 年 11 月 7 日に公開
  • Neowith Java をマスターする: セットアップ、クエリ、トランザクション、視覚化
    Neowith Java をマスターする: セットアップ、クエリ、トランザクション、視覚化
    Neo4j は、高度に接続されたデータの管理に優れた強力なグラフ データベースです。 Java と組み合わせると、複雑な関係モデリングを必要とするアプリケーションを構築するための堅牢なソリューションが提供されます。この投稿では、Java で Neo4j を使用するための基本を説明し、セットアップ、ク...
    プログラミング 2024 年 11 月 7 日に公開
  • JavaScript の主なバグ (およびその回避方法)
    JavaScript の主なバグ (およびその回避方法)
    JavaScript は非常に強力で適応性のある言語ですが、検出が難しい問題が発生する可能性もあります。このブログ記事では、開発者が JavaScript を使用する際に発見する最も一般的な 5 つの欠陥と、これらの問題の理由と解決策を見ていきます。経験豊富な開発者であっても、初心者であっても、これ...
    プログラミング 2024 年 11 月 7 日に公開
  • Laravel モデルでの熱心にロードされた関係を制限する
    Laravel モデルでの熱心にロードされた関係を制限する
    導入 Laravel モデルにリレーションシップを熱心に読み込む場合、返される関連モデルの数を制限したい場合があります。 たとえば、ブログ プラットフォームでは、システム内のすべての著者とその 3 つの投稿を読み込むことができます。 Laravel の古いバージョンでは、熱心にロー...
    プログラミング 2024 年 11 月 7 日に公開
  • GDB を使用して C++ でベクター要素を印刷する方法
    GDB を使用して C++ でベクター要素を印刷する方法
    GDB 経由で C でベクトル要素を出力GDB で C コードをデバッグする場合、std::vector の内容を調べるのは困難な場合があります。たとえば、myVector という名前の std::vector について考えてみましょう。要素を効果的に出力するにはどうすればよいですか?GCC 4.1...
    プログラミング 2024 年 11 月 7 日に公開
  • 異なるブラウザ間でドロップダウン リストの幅をカスタマイズするにはどうすればよいですか?
    異なるブラウザ間でドロップダウン リストの幅をカスタマイズするにはどうすればよいですか?
    IE ドロップダウン リストの幅の変更Internet Explorer では、ドロップダウン リストはドロップボックスの幅を反映しますが、Firefox では、ドロップダウン リストはドロップボックスの幅に適応します。内容。この制約により、最長の選択範囲を収容するためにドロップボックスを拡張する必...
    プログラミング 2024 年 11 月 7 日に公開
  • C++ で書式設定するときに出力文字列を右揃えにする方法
    C++ で書式設定するときに出力文字列を右揃えにする方法
    C での右揃えによる出力文字列の書式設定 座標などのデータを含むテキスト ファイルを処理する場合、項目を列に揃える必要があります適切なフォーマットのために問題が発生することがよくあります。 C では、この位置合わせを実現するには出力文字列の操作が重要です。この記事では、出力文字列の右揃えの問題に対処...
    プログラミング 2024 年 11 月 7 日に公開
  • CSS グラデーション ジェネレーター
    CSS グラデーション ジェネレーター
    シリーズ「無料 CSS ツール」へようこそ。 このシリーズでは、完全に無料で使いやすい CSS ツールを紹介します。 このツールの使用方法について説明した後、そのツールへのリンクを共有します。 ツール リンク: このツールは webdevtales.com で入手できます。 ツール...
    プログラミング 2024 年 11 月 7 日に公開

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3