React.memo vs useMemo vs cache
React.memo
is a higher-order component that we can use to wrap function components that we do not want to re-render unless props within them change.
Class components can be restricted from re-rendering when their input props are the same using PureComponent
or shouldComponentUpdate
.
useMemo
is a React Hook that is used to cache the result of a computationally expensive function between re-renders in a Client Component. We can use this to ensure that the values within that function are re-computed only when one of its dependencies change.
We can use cache
in Server Components to memoize work that can be shared across components. cache
should only be used in Server Components and the cache will be invalidated across server requests.
In summary, React.memo
is used to optimize the rendering of components, useMemo
is used to optimize the performance of specific function calls within a component while cache
is used to memoize work that can be shared across components in Server Components.