React フックのフロー: 詳しい説明
多くの開発者は React を知っていますが、理解が不足していると、物事がどのように機能するかについての思い込みが生じる可能性があります。 React のフック フローを明確に理解すると、コードの品質を大幅に向上させることができます。 React に 4 年以上取り組んできたので、見落とされがちな概念である React フックのフローに関する重要な洞察をいくつか共有したいと思います。
フックの流れに入る前に、フックのルールを再確認したいと思います
1.最上位レベルでのみフックを呼び出します
ループ、条件、またはネストされた
内でフックを呼び出さないでください。
代わりに、常に
の最上位レベルでフックを使用してください。
React 関数、初期リターンの前
2. React 関数 (コンポーネントまたはカスタム フック) からのみフックを呼び出します
通常の JavaScript 関数からフックを呼び出さないでください。
React フック フロー
この React フックのフロー図は、コンポーネントのライフサイクルのさまざまな段階でフックが呼び出される順序を視覚化するのに役立ちます。
コンポーネントのライフサイクルの各フェーズを見てみましょう。
初期マウント
これは、コンポーネントが初めて画面に読み込まれるときです。
遅延初期化子を実行する
React では、状態の初期化はコンポーネントのライフサイクル全体で 1 回だけ発生します。
「初期化」とは、useState の初期値が変数に 1 回だけ割り当てられることを意味します。
これはごく普通のことであり、通常は心配する必要はありません。ただし、ローカル ストレージから状態を設定するなど、初期化に複雑な計算が含まれる場合は、より重要になります。
const [userList, setUserList] = useState(localStorage.getItem("usersList"))
現在、localStorage.getItem("usersList") は再レンダリングのたびに実行されますが、その結果は状態変数に割り当てられません。この繰り返しの評価により、パフォーマンスの問題が発生する可能性があります。これを回避するには、マウント段階で 1 回だけ実行されるコールバック関数を useState に渡します。
const [userList, setUserList] = useState(() => localStorage.getItem("usersList"))
これは状態の遅延初期化と呼ばれます。詳細はこちらをご覧ください
遅延初期化は、再レンダリングのたびに不必要な初期化ロジックが実行されるのを防ぐのに役立ちます。
注: 状態の初期化に計算が含まれる場合にのみ、初期化関数を使用してください。
レンダリング
このステップでは、React が関数 (コンポーネント) を呼び出して、そのコンポーネントの仮想 DOM 表現を生成します。このプロセスは、コンポーネントが画面上でユーザーに表示されることを直接意味するものではありません。代わりに、UI がどのように見えるべきかを記述する仮想 DOM オブジェクトを React が作成する必要があります。
これは仮想 DOM (VDOM) オブジェクトの例です:
const [userList, setUserList] = useState(localStorage.getItem("usersList"))
VDOM オブジェクト
{
$$typeof: シンボル(react.element),
キー: null、
小道具: {子供たち: 「Hello World!」}、
参照: null、
タイプ: "h1" ,
......
};
React は DOM を更新します
仮想 DOM を生成し、それを調整して最終的な仮想 DOM を取得した後、React は実際の DOM をそれに応じて更新します。
LayoutEffects を実行
このステップには useLayoutEffect フックの実行が含まれます。このフックは useEffect に似ていますが、ブラウザーが描画を実行する前に実行されます。詳細については、こちらをご覧ください
ブラウザペイント画面
ブラウザは画面上に DOM を描画します
エフェクトを実行
これは useEffect フックが実行されるステップです。つまり、ブラウザーで UI をレンダリングした後です
useEffect に状態の更新がある場合、コンポーネントの更新ライフサイクルがトリガーされます
更新
状態の更新がトリガーされると、コンポーネントの更新ライフサイクルがトリガーされます
レンダリング、React は DOM を更新します
これらの手順は取り付け段階と似ています
LayoutEffects をクリーンアップ
仮想 DOM (VDOM) を作成し、実際の DOM を更新した後、React は useLayoutEffect フックのクリーンアップ関数を実行します。
注: useLayoutEffect の依存関係が変更されていない場合、クリーンアップ関数は実行されません。
LayoutEffects を実行
いずれかの依存関係の比較が変更を示す false を返した場合、useLayoutEffect が再度実行されます。それ以外の場合は実行されません。
ブラウザペイント画面
この時点で、ブラウザは更新された DOM を画面に表示します。
クリーンアップ効果、実行効果
useEffect のクリーンアップと実行は、以前のレンダリングと比較して依存関係に変更があった場合にのみ発生します。依存関係が変更されていない場合、クリーンアップ関数もエフェクトも実行されません。
アンマウント
これはコンポーネントのライフサイクルの最終段階であり、コンポーネントは DOM から削除され、ユーザーには表示されなくなります。
レイアウト効果のクリーンアップ、クリーンアップ効果
DOM からコンポーネントを削除する前に、React は useLayoutEffect フックと useEffect フックの両方のクリーンアップ関数をすべて実行します。
次回 UI でバグが発生した場合は、フック フローを視覚化してコード内の適切な箇所を特定し、問題を調査して解決します。これがあなたのコーディングスキルの向上に役立つことを願っています。コーディングを楽しんでください!
以上がReact フックのフロー: 詳しい説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











JavaScriptは現代のWeb開発の基礎であり、その主な機能には、イベント駆動型のプログラミング、動的コンテンツ生成、非同期プログラミングが含まれます。 1)イベント駆動型プログラミングにより、Webページはユーザー操作に応じて動的に変更できます。 2)動的コンテンツ生成により、条件に応じてページコンテンツを調整できます。 3)非同期プログラミングにより、ユーザーインターフェイスがブロックされないようにします。 JavaScriptは、Webインタラクション、シングルページアプリケーション、サーバー側の開発で広く使用されており、ユーザーエクスペリエンスとクロスプラットフォーム開発の柔軟性を大幅に改善しています。

JavaScriptの最新トレンドには、TypeScriptの台頭、最新のフレームワークとライブラリの人気、WebAssemblyの適用が含まれます。将来の見通しは、より強力なタイプシステム、サーバー側のJavaScriptの開発、人工知能と機械学習の拡大、およびIoTおよびEDGEコンピューティングの可能性をカバーしています。

さまざまなJavaScriptエンジンは、各エンジンの実装原則と最適化戦略が異なるため、JavaScriptコードを解析および実行するときに異なる効果をもたらします。 1。語彙分析:ソースコードを語彙ユニットに変換します。 2。文法分析:抽象的な構文ツリーを生成します。 3。最適化とコンパイル:JITコンパイラを介してマシンコードを生成します。 4。実行:マシンコードを実行します。 V8エンジンはインスタントコンピレーションと非表示クラスを通じて最適化され、Spidermonkeyはタイプ推論システムを使用して、同じコードで異なるパフォーマンスパフォーマンスをもたらします。

JavaScriptは、現代のWeb開発のコア言語であり、その多様性と柔軟性に広く使用されています。 1)フロントエンド開発:DOM操作と最新のフレームワーク(React、Vue.JS、Angularなど)を通じて、動的なWebページとシングルページアプリケーションを構築します。 2)サーバー側の開発:node.jsは、非ブロッキングI/Oモデルを使用して、高い並行性とリアルタイムアプリケーションを処理します。 3)モバイルおよびデスクトップアプリケーション開発:クロスプラットフォーム開発は、反応および電子を通じて実現され、開発効率を向上させます。

Pythonは、スムーズな学習曲線と簡潔な構文を備えた初心者により適しています。 JavaScriptは、急な学習曲線と柔軟な構文を備えたフロントエンド開発に適しています。 1。Python構文は直感的で、データサイエンスやバックエンド開発に適しています。 2。JavaScriptは柔軟で、フロントエンドおよびサーバー側のプログラミングで広く使用されています。

この記事では、許可によって保護されたバックエンドとのフロントエンド統合を示し、next.jsを使用して機能的なedtech SaaSアプリケーションを構築します。 FrontEndはユーザーのアクセス許可を取得してUIの可視性を制御し、APIリクエストがロールベースに付着することを保証します

C/CからJavaScriptへのシフトには、動的なタイピング、ゴミ収集、非同期プログラミングへの適応が必要です。 1)C/Cは、手動メモリ管理を必要とする静的に型付けられた言語であり、JavaScriptは動的に型付けされ、ごみ収集が自動的に処理されます。 2)C/Cはマシンコードにコンパイルする必要がありますが、JavaScriptは解釈言語です。 3)JavaScriptは、閉鎖、プロトタイプチェーン、約束などの概念を導入します。これにより、柔軟性と非同期プログラミング機能が向上します。

JavaScriptは、最新のブラウザにすでに組み込まれているため、インストールを必要としません。開始するには、テキストエディターとブラウザのみが必要です。 1)ブラウザ環境では、タグを介してHTMLファイルを埋め込んで実行します。 2)node.js環境では、node.jsをダウンロードしてインストールした後、コマンドラインを介してJavaScriptファイルを実行します。
