React16.8 の新しい useEffec フック関数は、副作用を処理するために使用されます。 いわゆる「副作用」の簡単な例を挙げると、風邪をひいていて薬を飲んでも大丈夫なのに、薬を飲んだ後に体がその薬に対してアレルギー反応を起こす、この「アレルギー」が副作用です。 Reactでは、本来はDOMをレンダリングしてページに表示したいだけなのですが、DOM以外にもデータがあり、このデータを外部データソースから取得する必要があります。「外部データソースを取得する」という処理が副作用です。 useEffect の使い方については、公式サイトに掲載されている例を参考にしてください。ここでは主に useEffect の使用時に発生する問題についてまとめます。 繰り返しレンダリングループを避けるuseEffect を使用して配列を第 2 パラメータとして受け取り、第 2 パラメータを依存関係として使用します。DOM がレンダリングされ、副作用関数が実行されるたびに、依存関係のレンダリング前後の値が一致しているかどうかを確認するための浅い比較が行われます。一致していない場合は副作用が実行され、一致していない場合は実行されません。依存関係が空の配列 [] の場合、つまり比較する変数が渡されていない場合は、比較結果は常に変更されず、副作用ロジックは 1 回しか実行されません。 使用効果(() => { タイムアウトを設定する(() => { setCounter(カウンター + 1); }, 300) }, []); さらに、更新ボタンをクリックして外部データを取得したいが、無限ループを引き起こしたくない場合は、変数を「スイッチ」として使用して、DOM の循環レンダリングを回避しながら目的を達成できます。
function App() { const [count, setCount] = useState(0); const [loading, setLoading] = useState(true); // スイッチとしてロードします useEffect(() => { if (loading) { // これはロードが true の場合にのみ実行されることに注意してください setTimeout(() => { setCount(count + 1); setLoading(!loading); // ロード値を変更します }); } }, [loading]); // ここではロードが依存関係として使用されます // 最初の DOM レンダリングが完了した後、loading が true になり、副作用関数が実行され、count 値が 1 になり、loading が false になります。// state の値が変更されるため、更新され、コンポーネントが再度レンダリングされますが、この時点では loading が false であり、setTimeout は実行されません。 // ループを回避する // [更新] をクリックすると、読み込みが false から true に変わり、関数は更新を実行します // DOM が更新された後、useEffect が実行されます。loading がすでに true になっているため、副作用関数が実行でき、count が 1 から 2 に変わります。 // ロードすると true から false に変わります。 。 。 return ( <div> <h3>{count}</h3> <button onClick={() => { setLoading(true); }} > 更新 </button> </div> );} 副作用の除去についてuseEffect は副作用をクリーンアップする関数を返すことができます。 使用効果(() => { ChatAPI.subscribeToFriendStatus(props.id、handleStatusChange); 関数クリア(){ ChatAPI.unsubscribeFromFriendStatus(props.id、handleStatusChange); } クリアを返す; }); これには、useEffect の実行と破棄のプロセスが含まれます。
このことから、副作用クリーンアップ関数の特性を推測できます。
出力されたカウント値から、次の副作用関数が実行される前にクリア関数が実行されることもわかります。つまり、クリア関数のカウント値は最後のキャッシュのカウント値です。 さらに考えてみると、clear1 を実行すると props.id にアクセスされるので、この id の値は 1 でしょうか、それとも 2 でしょうか? これにはクロージャの概念が関係します。useEffect は関数を返し、この関数は実行時にクロージャを生成するからです。クロージャの定義によれば、返された clear 関数は自身のスコープ外の変数にアクセスできます。コンポーネントが初めてレンダリングされるときに id=1 が渡され、clear 関数の props.id の値は 1 になります。 以上がReact useEffectの理解と使用に関する詳細な内容です。React useEffectについてさらに詳しく知りたい方は、123WORDPRESS.COMの他の関連記事もぜひご覧ください! 以下もご興味があるかもしれません:
|
>>: Linux で SSH 経由でリモート ファイルシステムをマウントする方法の詳細な説明
Jenkins はオープンソース ソフトウェア プロジェクトです。Java をベースに開発された継続...
目次1. Tomcatコードをダウンロードする2. ダウンロード後のディレクトリ構造3. ソースコー...
MySQL 5.7.9 のインストールチュートリアルを録画してみんなと共有しましょう環境の紹介:オペ...
LNMP とは: Linux+Nginx+Mysql+(php-fpm、php-mysql)つまり、...
目次1. CentOS7+MySQL8.0、yumソースインストール2. MySQLにログインしてパ...
1. まずシステムにmysqlがインストールされているかどうかを確認します rpm -qa | gr...
アクセス数が増えると、MySQL データベースへの負荷が増大します。MySQL アーキテクチャを使用...
まずエラーコードを見てみましょう。 html: <テーブルボーダー="1"...
1. my.iniファイルにskip-grant-tablesを追加し、MySQLサーバーを再起動し...
目次Vuex とは何ですか? Vuex 使用サイクル図私のストアディレクトリvuexの例の実装要約す...
Ubuntu 20.04 をインストールした後、デフォルトでは root アカウントのログイン権限が...
目次MySQL 内部結合、左結合、右結合、外部結合、複数テーブルクエリビルド環境: 1. 内なる慈恩...
プロジェクト要件: 製品ツリー ノードをクリックすると、そのノードのすべての親ノードが取得され、表に...
CentosでのMySQLのインストールについては、以前の記事を参照してください。 Centos7....
1. クラスター化インデックステーブル データはインデックスの順序で保存されます。つまり、インデック...