「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > useState が Strict モードでコンポーネントを 2 回レンダリングするのはなぜですか?

useState が Strict モードでコンポーネントを 2 回レンダリングするのはなぜですか?

2024 年 11 月 9 日に公開
ブラウズ:954

Why Does useState Render Components Twice in Strict Mode?

useState での二重レンダリングについて理解する

React では、コンポーネントの状態を管理するために useState フックがよく使用されます。ただし、特定の条件下では、useState でレンダリングされたコンポーネントが状態の更新ごとに 2 回レンダリングされることに気づく場合があります。この動作は、厳密モードを有効にしていない多くの開発者を混乱させています。なぜこのようなことが起こるのでしょうか?

厳密モードの役割

厳密モードが有効になっていないという想定に反して、コードは実際にはその制約の下で実行されています。デフォルトでは、React の最新バージョンは、最も外側のコンポーネントを 要素で暗黙的にラップします。このモードはデバッグを強化し、潜在的なパフォーマンスの問題を強調します。

Strict モードでの Double Function Invocation

React のドキュメントには、Strict モードでは特定の関数を意図的に「二重呼び出し」することが明記されています。これには、setState および useState に渡される状態アップデーター関数が含まれます。これは、コード内で setNumber を呼び出すたびに、setNumber が 2 回呼び出されることを意味します。

二重呼び出しの結果

この二重呼び出しにより、コンポーネントが 2 回レンダリングされます。この動作は、開発者が潜在的な副作用をより決定論的に特定できるようにすることを目的としています。デフォルトでは、React は useState フックを使用するときに更新を延期します。ただし、Strict モードではこの動作がバイパスされ、レンダリングが 2 回発生します。

結論

要約すると、useState を使用したコンポーネントの二重レンダリングは、 React の Strict モードでのコード。予想外に見えるかもしれませんが、この動作は意図的であり、副作用をより明確にすることでデバッグ機能を強化するように設計されています。

リリースステートメント この記事は次の場所に転載されています: 1729694788 権利侵害がある場合は、[email protected] に連絡して削除してください。
最新のチュートリアル もっと>

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

Copyright© 2022 湘ICP备2022001581号-3