「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > React の再レンダリング: 最適なパフォーマンスのためのベスト プラクティス

React の再レンダリング: 最適なパフォーマンスのためのベスト プラクティス

2024 年 11 月 5 日に公開
ブラウズ:172

React Re-Rendering: Best Practices for Optimal Performance

React の効率的なレンダリング メカニズムは、その人気の主な理由の 1 つです。ただし、アプリケーションが複雑になるにつれて、コンポーネントの再レンダリングの管理がパフォーマンスを最適化するために重要になります。 React のレンダリング動作を最適化し、不必要な再レンダリングを回避するためのベスト プラクティスを探ってみましょう。

1. 機能コンポーネントには React.memo() を使用する

React.memo() は、機能コンポーネントのレンダリングをメモ化する高次コンポーネントです。現在のプロップと以前のプロップの浅い比較を実行することで、不必要な再レンダリングを防ぎます。プロパティが変更されていない場合、React はコンポーネントのレンダリングをスキップし、最後にレンダリングされた結果を再利用します。

import React from 'react';

const MemoizedComponent = React.memo(function MyComponent(props) {
  // Component logic
});

2. クラスコンポーネントの PureComponent の実装

クラス コンポーネントを使用している場合は、Component の代わりに PureComponent を拡張することを検討してください。 PureComponent は、プロパティと状態の浅い比較を実行して、コンポーネントを更新する必要があるかどうかを判断します。これは、プロパティと状態が変更されていない場合に不必要な再レンダリングを回避するのに役立ちます。

import React, { PureComponent } from 'react';

class MyComponent extends PureComponent {
  // Component logic
}

3. インライン関数定義を避ける

render メソッド内で関数を定義すると、不必要な再レンダリングが発生する可能性があります。代わりに、render メソッドの外側で関数を定義するか、簡潔なイベント ハンドラーにアロー関数を使用します。

class MyComponent extends React.Component {
  handleClick = () => {
    // Handle click
  };

  render() {
    return ;
  }
}

4. useCallback フックを使用する 関数をメモ化する

useCallback フックは関数をメモ化するために使用されます。これにより、レンダリングごとに関数が不必要に再作成されるのを防ぎます。これにより、これらの関数に依存する子コンポーネントが不必要に再レンダリングされる可能性があります。

import React, { useCallback } from 'react';

function MyComponent() {
  const handleClick = useCallback(() => {
    // Handle click
  }, []);

  return ;
}

5. 高コストの計算には useMemo フックを活用する

useMemo フックは、高価な計算をメモ化するために使用されます。これにより、レンダリングごとに値の不必要な再計算が防止され、特に複雑な計算のパフォーマンスが向上します。

import React, { useMemo } from 'react';

function MyComponent({ items }) {
  const filteredItems = useMemo(() => items.filter(item => item.visible), [items]);

  return (
    
    {filteredItems.map(item => (
  • {item.name}
  • ))}
); }

6. リスト内でキーを正しく使用する

コンポーネントのリストをレンダリングするときは、常に一意のキー プロパティを指定します。 React はキーを使用して、調整中に要素を効率的に識別します。キーが間違っているか欠落していると、パフォーマンスの問題や予期しない動作が発生する可能性があります。

    {items.map(item => (
  • {item.name}
  • ))}

7. 動的インポートを使用した コード分割の実装

コード分割を使用すると、アプリケーションのコードをより小さなチャンクに分割できます。動的インポート (import()) を使用すると、アプリケーションの一部をオンデマンドでロードできるため、初期バンドル サイズが削減され、ロード時間が短縮されます。

import React, { lazy, Suspense } from 'react';

const MyComponent = lazy(() => import('./MyComponent'));

function App() {
  return (
    Loading...}>
      
    
  );
}

8. 大きなリストに対する ウィンドウ処理の実装

仮想化とも呼ばれるウィンドウ化には、現在画面上に表示されている項目のみのレンダリングが含まれます。この手法は、最初のレンダリング時間を短縮し、スクロールのパフォーマンスを向上させるため、大きなリストを扱う場合に特に役立ちます。

react-virtualized や React-window などのライブラリは、React アプリケーションのウィンドウ処理の効率的な実装を提供します。

9. 画像の遅延読み込みを実装

画像の遅延読み込みにより、アプリケーションの初期読み込み時間を大幅に短縮できます。イメージが必要になるまで (つまり、ビューポートに表示される直前まで) イメージの読み込みを遅らせることで、初期バンドル サイズを削減し、知覚されるパフォーマンスを向上させることができます。

react-lazyload や react-lazy-load-image-component などのライブラリは、React アプリケーション用の使いやすい遅延読み込みソリューションを提供します。

10. 不変のデータ構造を使用する

不変のデータ構造は、詳細な等価性チェックの必要性を減らし、React のレンダリング パフォーマンスの最適化に役立ちます。不変データを使用する場合、React は詳細な比較を実行するのではなく、データの参照を比較することで、コンポーネントを再レンダリングする必要があるかどうかを迅速に判断できます。

Immutable.js や Immer などのライブラリは、React アプリケーションで不変データを操作するための不変データ構造とヘルパー関数を提供します。

結論

React のレンダリング パフォーマンスを最適化することは、スムーズで応答性の高いユーザー エクスペリエンスを提供するために重要です。これらのベスト プラクティスに従い、React の組み込み機能とフックを活用することで、ユーザーを満足させる高性能の React アプリケーションを作成できます。

アプリケーションのパフォーマンスを継続的にプロファイリングおよび測定して、ボトルネックや改善の余地がある領域を特定することを忘れないでください。 React DevTools やパフォーマンス監視ソリューションなど、React のツールとライブラリの豊富なエコシステムは、このプロセスに役立ちます。

React 開発 に関する専門家のサポートが必要な場合は、ViitorCloud Technologies に問い合わせて、熟練した ReactJS 開発者を雇用してください。

リリースステートメント この記事は次の場所に転載されています: https://dev.to/viitorcloud/react-re-rendering-best-practices-for-optimal-performance-30bo?1 侵害がある場合は、削除するために [email protected] に連絡してください。それ
最新のチュートリアル もっと>

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

Copyright© 2022 湘ICP备2022001581号-3