「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > React.memo を理解する: 機能コンポーネントの最適化

React.memo を理解する: 機能コンポーネントの最適化

2024 年 11 月 8 日に公開
ブラウズ:165

Understanding React.memo: Optimizing Functional Components

React.memo は、機能コンポーネントの不必要な再レンダリングを防止することでパフォーマンスを最適化するために React で使用される高次コンポーネントです。これは、コンポーネントの結果をメモ化し、プロパティが変更された場合にのみ再レンダリングすることで機能します。これは、同じ props を与えて同じ出力をレンダリングする機能コンポーネントのパフォーマンスの最適化に役立ちます。

使用例:

import React from 'react';

const MyComponent = ({ count }) => {
  console.log('Component re-rendered');
  return 
Count: {count}
; }; export default React.memo(MyComponent);

この例では、MyComponent は count prop が変更された場合にのみ再レンダリングされます。親コンポーネントが再レンダリングされても count prop が同じままの場合、MyComponent は再レンダリングされず、不必要な計算が削減されます。

デフォルトでは、React.memo はプロパティの浅い比較を実行しますが、必要に応じて、より深いチェックのためのカスタム比較関数を提供することもできます:

const MyComponent = React.memo((props) => {
  /* component code */
}, (prevProps, nextProps) => {
  // return true if props are equal, false otherwise
  return prevProps.someValue === nextProps.someValue;
});

これにより、より複雑なプロップ構造がある場合、パフォーマンスをさらに最適化できます。

リリースステートメント この記事は次の場所に転載されています: https://dev.to/imyusufakhtar/ Understanding-reactmemo-optimizing-function-components-31ln?1 侵害がある場合は、[email protected] に連絡して削除してください。
最新のチュートリアル もっと>

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

Copyright© 2022 湘ICP备2022001581号-3