コンポーネントの遅延読み込みで React アプリのパフォーマンスを向上させる
React でのコンポーネントの遅延読み込み
遅延読み込み は、必要な場合にのみコンポーネントをロードできる React の手法です。これにより、最初はアプリの必要な部分のみがロードされ、残りは必要に応じて動的にロードされるため、初期ロード時間が短縮され、アプリケーションのパフォーマンスが向上します。
React は、遅延読み込みを実装するための React.lazy 関数と Suspense コンポーネントを提供します。
遅延読み込みの仕組み
- React.lazy: コンポーネントを動的にインポートします。
- Suspense: コンポーネントのロード中にフォールバック (ロード スピナーなど) を表示します。
構文
const LazyComponent = React.lazy(() => import('./path/to/Component')); function App() { return ( <React.Suspense fallback={<div>Loading...</div>}> <LazyComponent /> </React.Suspense> ); }
- React.lazy: 指定されたコンポーネントを動的にインポートします。
- Suspense: 遅延ロードされたコンポーネントをラップし、コンポーネントのロード中にフォールバック UI を提供します。
例 1: 基本的な遅延読み込み
遅延読み込みなし
import React from "react"; import HeavyComponent from "./HeavyComponent"; function App() { return ( <div> <h1>App Component</h1> <HeavyComponent /> </div> ); } export default App;
この例では、HeavyComponent はすぐに必要でない場合でも常にロードされるため、初期ロード時間が長くなります。
遅延読み込みあり
import React, { Suspense } from "react"; const HeavyComponent = React.lazy(() => import("./HeavyComponent")); function App() { return ( <div> <h1>App Component</h1> <Suspense fallback={<div>Loading Heavy Component...</div>}> <HeavyComponent /> </Suspense> </div> ); } export default App;
現在、HeavyComponent はレンダリング時にのみロードされます。コンポーネントがフェッチされている間、フォールバック UI (例: 「重いコンポーネントを読み込んでいます...」) が表示されます。
例 2: React Router を使用した遅延ロード
遅延読み込みは、特定のルートがアクセスされた場合にのみコンポーネントをロードするルーティングで特に役立ちます。
import React, { Suspense } from "react"; import { BrowserRouter as Router, Routes, Route } from "react-router-dom"; const Home = React.lazy(() => import("./Home")); const About = React.lazy(() => import("./About")); const Contact = React.lazy(() => import("./Contact")); function App() { return ( <Router> <Suspense fallback={<div>Loading Page...</div>}> <Routes> <Route path="/" element={<Home />} /> <Route path="/about" element={<About />} /> <Route path="/contact" element={<Contact />} /> </Routes> </Suspense> </Router> ); } export default App;
- React.lazy: /about や /contact などのルートのコンポーネントを遅延読み込みします。
- Suspense: コンポーネントのロード中にフォールバック UI を表示します。
遅延読み込みの利点
- パフォーマンスの向上: 不要なコンポーネントのロードを延期することで、初期ロード時間を短縮します。
- ユーザー エクスペリエンスの向上: コンポーネントを動的に読み込み、応答性の高いアプリの作成に役立ちます。
- バンドル サイズの縮小: コードをより小さなチャンクに分割し、最初にロードされる JavaScript バンドルのサイズを最小限に抑えます。
高度な例: 複数のコンポーネントの遅延ロード
複数のコンポーネントを遅延読み込みし、条件付きレンダリングと組み合わせることができます。
const LazyComponent = React.lazy(() => import('./path/to/Component')); function App() { return ( <React.Suspense fallback={<div>Loading...</div>}> <LazyComponent /> </React.Suspense> ); }
遅延読み込みによるエラー処理
遅延ロードされたコンポーネントのロードに失敗した場合 (ネットワークエラーなど)、React は遅延ロード用の組み込みエラー処理を提供しません。 ErrorBoundary を使用して、このようなシナリオを処理できます。
import React from "react"; import HeavyComponent from "./HeavyComponent"; function App() { return ( <div> <h1>App Component</h1> <HeavyComponent /> </div> ); } export default App;
遅延読み込みのベスト プラクティス
- フォールバックをシンプルに保つ: スピナーやテキスト メッセージなどの軽量のフォールバック UI を使用します。
- コンポーネントを賢く分割します: ルートごと、機能ごとなど、コンポーネントを論理的に分割します。
- コード分割と組み合わせる: Webpack や Vite などのツールを使用して、効果的にコードを分割します。
結論
React の遅延読み込みは、アプリケーションのパフォーマンスを向上させ、ユーザー エクスペリエンスを最適化する強力な方法です。 React.lazy と Suspense を使用してコンポーネントを動的にロードすることで、初期ロード時間を短縮し、アプリケーションの必要な部分のみが確実にフェッチされるようにすることができます。
以上がコンポーネントの遅延読み込みで React アプリのパフォーマンスを向上させるの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undress AI Tool
脱衣画像を無料で

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

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

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

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

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

node.jsでHTTPリクエストを開始するには、組み込みモジュール、axios、およびnode-fetchを使用する3つの一般的な方法があります。 1.依存関係のない内蔵http/httpsモジュールを使用します。これは基本的なシナリオに適していますが、https.get()を使用してデータを取得したり、.write()を介してPOSTリクエストを送信するなど、データステッチとエラーモニタリングの手動処理が必要です。 2.Axiosは、約束に基づいたサードパーティライブラリです。簡潔な構文と強力な機能を備えており、非同期/待ち声、自動JSON変換、インターセプターなどをサポートします。非同期リクエスト操作を簡素化することをお勧めします。 3.Node-Fetchは、約束と単純な構文に基づいて、ブラウザフェッチに似たスタイルを提供します

JavaScriptデータ型は、プリミティブタイプと参照タイプに分割されます。プリミティブタイプには、文字列、数字、ブール、ヌル、未定義、シンボルが含まれます。値は不変であり、コピーは値を割り当てるときにコピーされるため、互いに影響を与えません。オブジェクト、配列、関数などの参照タイプはメモリアドレスを保存し、同じオブジェクトを指す変数は互いに影響します。 TypeofとInstanceOFを使用してタイプを決定できますが、TypeOfNullの歴史的な問題に注意してください。これらの2種類の違いを理解することは、より安定した信頼性の高いコードを書くのに役立ちます。

JavaScriptのフィルター()メソッドは、すべての合格テスト要素を含む新しい配列を作成するために使用されます。 1.Filter()は元の配列を変更しませんが、条件付き要素を満たす新しい配列を返します。 2。基本的な構文はarray.filter((element)=> {returnCondition;})です。 3.オブジェクト配列は、30歳以上のユーザーをフィルタリングするなど、属性値でフィルタリングできます。 4.年齢と名前の長さの条件を同時に満たすなど、マルチコンディショナルフィルタリングをサポートします。 5。動的条件を処理し、フィルターパラメーターを関数にパスして、柔軟なフィルタリングを実現できます。 6.それを使用する場合は、空のアレイの返品を避けるためにブール値を返すように注意し、他の方法を組み合わせて文字列マッチングなどの複雑なロジックを実現してください。

JavaScriptでは、配列に特定の値が含まれているかどうかを確認します。最も一般的な方法は、boolean値を返す()を含む()であり、構文はarray.includes(valuetofind)です。古い環境と互換性がある必要がある場合は、numbers.indexof(20)!== -1などのindexof()を使用します。オブジェクトまたは複雑なデータの場合、ユーザー(user => user.id === 1)などの綿密な比較には、いくつかの()メソッドを使用する必要があります。

Virtual Domは、実際のDOM更新を最適化するプログラミングコンセプトです。メモリ内の実際のDOMに対応するツリー構造を作成することにより、実際のDOMの頻繁かつ直接的な動作を避けます。その中心的な原則は次のとおりです。1。データが変更されたときに新しい仮想DOMを生成します。 2。新しい仮想ドームと古い仮想ドームの最小の違いを見つけます。 3.再配置と再描画のオーバーヘッドを減らすための実際のDOMのバッチアップデート。さらに、ユニークな安定したキーを使用すると、リストの比較効率を改善できますが、最新のフレームワークでは他のテクノロジーを採用して仮想DOMを置き換えます。

非同期関数のエラーを処理するには、トライ/キャッチを使用し、コールチェーンでそれらを処理し、.catch()メソッドを使用して、unhandledRejectionイベントをリッスンします。 1.トライ/キャッチに使用するためにエラーをキャッチすることは、明確な構造を備えた推奨方法であり、待ち望みの例外を処理できます。 2。コールチェーンの取り扱いエラーは、マルチステッププロセスに適した集中ロジックにすることができます。 3. .catch()を使用して、Async関数を呼び出した後にエラーをキャッチします。これは、Promiseの組み合わせシナリオに適しています。 4.未処理のイベントに耳を傾けて、未処理の拒否を最後の防衛線として記録します。上記の方法は、非同期エラーが正しくキャプチャおよび処理されることを共同で保証します。

JavaScriptタイムゾーンの問題に対処するための鍵は、適切な方法を選択することです。 1.ネイティブの日付オブジェクトを使用する場合は、UTC時間に保存および転送し、表示時にユーザーのローカルタイムゾーンに変換することをお勧めします。 2。複雑なタイムゾーン操作の場合、IANAタイムゾーンデータベースをサポートし、便利なフォーマットおよび変換機能を提供するモーメントタイムゾーンを使用できます。 3.表示時間をローカライズする必要があり、サードパーティライブラリを導入したくない場合は、intl.dateTimeformatを使用できます。 4.最新の軽量ソリューションDay.JSおよびTimeZoneおよびUTCプラグインに推奨されます。

functionprogramminginjavascriptemphasizes clean、predictablecodethroghcoreconcepts.1.purefunctionsconsconsientlyturturturturturtputputtitputitedside effects、改善可能性と予測可能性
