DEV Community

Abhay Singh Kathayat
Abhay Singh Kathayat

Posted on

Understanding React.memo for Performance Optimization in React

React.memo is a higher-order component (HOC) that helps optimize the performance of React components by preventing unnecessary re-renders. It is used to memoize functional components, which means React will skip re-rendering the component if its props haven't changed. This is particularly useful for performance optimization in large React applications where re-rendering may be costly.

How React.memo Works

React.memo works by performing a shallow comparison of the props of the component. If the props are the same as the previous render, React will skip rendering the component and use the result from the previous render instead. This can significantly reduce the number of re-renders and improve performance, especially when rendering large lists or expensive components.

Syntax

const MemoizedComponent = React.memo(Component);
Enter fullscreen mode Exit fullscreen mode

Where:

  • Component is the functional component you want to memoize.
  • MemoizedComponent is the new memoized version of the component.

Example: Basic Usage of React.memo

Let's look at a simple example of how React.memo can be used:

import React, { useState } from 'react';

const ChildComponent = React.memo(({ name }) => {
  console.log("Child component re-rendered");
  return <div>Hello, {name}!</div>;
});

function App() {
  const [name, setName] = useState('John');
  const [count, setCount] = useState(0);

  return (
    <div>
      <ChildComponent name={name} />
      <button onClick={() => setName('Doe')}>Change Name</button>
      <button onClick={() => setCount(count + 1)}>Increment Count</button>
      <p>Count: {count}</p>
    </div>
  );
}

export default App;
Enter fullscreen mode Exit fullscreen mode

Explanation:

  • ChildComponent is wrapped in React.memo. It only re-renders when the name prop changes.
  • App has two pieces of state: name and count. Clicking the "Increment Count" button doesn't change the name prop, so the ChildComponent doesn't re-render when the count state is updated.
  • If you click "Change Name", the name prop changes, causing ChildComponent to re-render.

Output:

  • When you click the "Increment Count" button, the ChildComponent will not re-render, but it will log "Child component re-rendered" when the name prop changes.

Custom Comparison with React.memo

By default, React.memo performs a shallow comparison of props, but you can provide a custom comparison function if you need more control over how props are compared.

The custom comparison function should return true if the component should not re-render and false if it should.

Example: Custom Comparison Function

const ChildComponent = React.memo(
  ({ name, age }) => {
    console.log("Child component re-rendered");
    return <div>Hello, {name}, {age}!</div>;
  },
  (prevProps, nextProps) => {
    // Custom comparison: only re-render if name changes
    return prevProps.name === nextProps.name;
  }
);

function App() {
  const [name, setName] = useState('John');
  const [age, setAge] = useState(30);

  return (
    <div>
      <ChildComponent name={name} age={age} />
      <button onClick={() => setName('Doe')}>Change Name</button>
      <button onClick={() => setAge(age + 1)}>Increment Age</button>
    </div>
  );
}
Enter fullscreen mode Exit fullscreen mode

In this example, the ChildComponent will only re-render when the name prop changes, even if the age prop changes, thanks to the custom comparison function.

When to Use React.memo

  • Performance Optimization: If you have functional components that receive props and do not change often, React.memo can help avoid unnecessary renders.
  • List Rendering: For large lists where only a few elements change, React.memo can be very useful. For example, when rendering a list of items, memoizing each list item component will prevent re-renders of unchanged items.
  • Expensive Components: If a component has expensive rendering logic (e.g., complex calculations or rendering heavy data), using React.memo can improve the overall performance by avoiding unnecessary recalculations.

When Not to Use React.memo

  • Small Components: For small components with few props, using React.memo may add overhead without providing a significant performance boost.
  • Changing Props Frequently: If a component receives props that change frequently, React.memo may not offer much benefit since the component will re-render anyway.
  • Complex Comparison Logic: Custom comparison logic can be more expensive than just allowing the component to re-render normally. Only use it when necessary.

Conclusion

React.memo is a simple yet powerful optimization tool in React for preventing unnecessary re-renders of functional components. By memoizing components and using shallow prop comparison (or a custom comparison function), React can skip rendering those components when their props haven't changed, leading to performance improvements, especially in large or complex applications.

Top comments (4)

Collapse
 
juniourrau profile image
Ravin Rau

Great article on React.memo! It's a handy tool for optimizing performance by reducing unnecessary re-renders. However, with React 19's new compiler, many optimizations are now automatic, so using React.memo might not be as necessary. Exciting times for React developers! 🚀

Collapse
 
abhay_yt_52a8e72b213be229 profile image
Abhay Singh Kathayat

Absolutely! React.memo is indeed a powerful tool for optimizing performance by preventing unnecessary re-renders, especially in large applications. With React 19's new compiler and automatic optimizations, many performance improvements are being handled under the hood, which is great news for developers! 🚀 It's exciting to see how React continues to evolve, making things more efficient and reducing the need for manual optimizations. Still, it's good to know about React.memo in case we need fine-grained control over performance in specific cases. 😊

Collapse
 
richard_abner_9cb64530e03 profile image
Richard Abner

Hello you got telegram or Twitter so we can talk on a deal

Collapse
 
abhay_yt_52a8e72b213be229 profile image
Abhay Singh Kathayat

Thank you for reaching out. You can connect with me on Twitter at @AbhaySingh281. I look forward to discussing this further.