遅延読み込みは、すべてを事前に読み込むのではなく、必要なときにのみコンポーネントを読み込むことができる Web 開発の手法です。これは、すべてのコンポーネントを一度に読み込むと最初のページの読み込みが遅くなる可能性がある大規模なアプリケーションで特に役立ちます。
React Router v6 は、React の組み込み React.lazy および Suspense とシームレスに連携して、ルートの遅延読み込みを実装します。これらの機能を使用すると、ユーザーがコンポーネントに移動したときにのみコンポーネントを読み込むことで、アプリのパフォーマンスとユーザー エクスペリエンスを向上させることができます。
React では、コンポーネントを動的にインポートするために React.lazy が使用され、フェッチ中に遅延ロードされたコンポーネントをラップするために Suspense が使用されます。 React Router v6 では、これらの概念を簡単に統合してルートを遅延読み込みできます。
React.lazy を使用してコンポーネントを遅延ロードする
Suspense を使用して遅延ロードされたコンポーネントをラップする
React Router v6 がインストールされていることを確認してください:
npm install react-router-dom@6
import React, { Suspense } from 'react'; import { BrowserRouter as Router, Routes, Route } from 'react-router-dom'; // Lazy load components using React.lazy const Home = React.lazy(() => import('./Home')); const About = React.lazy(() => import('./About')); const Contact = React.lazy(() => import('./Contact')); // Fallback UI component to show while lazy-loaded component is loading const FallbackLoader = () => <div>Loading...</div>; const App = () => { return ( <Router> <Suspense fallback={<FallbackLoader />}> <Routes> <Route path="/" element={<Home />} /> <Route path="/about" element={<About />} /> <Route path="/contact" element={<Contact />} /> </Routes> </Suspense> </Router> ); }; export default App;
React.lazy(() => import('./Home')):
サスペンス:
サスペンスのフォールバック プロップ:
遅延読み込みはネストされたルートにも適用でき、ネストされたコンポーネントを含むページの読み込み時間を改善します。
npm install react-router-dom@6
チャンク化とコード分割: React Router を使用すると、アプリをチャンクに分割し、各ルートをオンデマンドでロードできる個別のバンドルにすることができます。これにより、初期ロード時間が短縮され、アプリの速度が向上します。
フォールバックを賢く使用する: フォールバック UI が優れたユーザー エクスペリエンスを提供するようにしてください。通常は、単純な読み込みスピナーまたはテキストで十分ですが、さらにカスタマイズすることもできます。
重要なルートのプリロード: ユーザーが最初に移動する可能性が高い重要なページについては、これらのルートをバックグラウンドでプリロードして、ユーザーがそれらのルートに移動したときに準備できるようにすることを検討してください。
遅延読み込みを制限する: 重要ではないコンポーネントには遅延読み込みを使用します。初期読み込み時間に大きな影響を与えない小さなコンポーネントに対して遅延読み込みを過度に使用しないでください。
React.lazy と Suspense を利用した React Router v6 の遅延読み込みは、必要なときにのみコンポーネントを読み込み、React アプリケーションのパフォーマンスを最適化するのに役立ちます。初期ロード時間を短縮することでユーザー エクスペリエンスが向上し、大規模なアプリケーションを効率的に管理できるようになります。
React Router v6 では、コード分割用の React.lazy とフォールバック UI 用の Suspense を組み合わせることで、トップレベル ルートとネストされたルートの両方に遅延読み込みを簡単に実装できます。
以上がReact Router v6 での遅延読み込みによるパフォーマンスの最適化の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。