Frontend Snacks ๐Ÿฟ

๐Ÿฟ The mystery of Memoization in React

Hey friend,

I have got to admit. I took the knowledge of Hooks I had for granted. I thought everyone knew what Memoization is and that useCallback and useMemo are simple hooks to learn.

Because I had experience working for so many years and building enterprise-level apps, so I thought that useCallback and memo were so common that I didn't even mention them.

When I started speaking at conferences and talking to the attendees, I realized I was wrong ๐Ÿ˜….

Many thanked me and told me that they finally understood what Memoization was and the differences between the hooks
after 4 years of working in React.

That comment was very sweet and made my day, but I was shocked. Hence, I want to bridge the gap for all of you today.

Today, let's learn what Memoization is and how we can use it.

๐ŸฟOur Weekly Snack: Memoization in React

๐Ÿ’ก Memoization is how the results of a function get cached so the program does not have to re-calculate those results. It is like caching.

Now, if we were to build a dark mode app, you can easily profile that app to see how often it re-renders. Here is how you can do so. Let's turn on the option to profile our app, aka measure its performance. Here is how we can do that. Go to Developer tools โ†’ Profiler.

Also, could you check this option, as we want updates to get highlighted when components re-render?

Once you click on "start profile ๐Ÿ”ด," notice how the Logo and Footer keep flashing, which means it keeps re-rendering. You can totally avoid this, as we never want these components to keep re-rendering.โ€‹โ€‹

We can solve this by Memoizing the Logo and Footer. Here is how we can cache Logo so it won't be re-rendered.

Next week, we will learn useCallback, deal? ๐Ÿ˜‰

Like this newsletter? Share it with friends and co-workers!

โ€‹

Latest Frontend Gossip/News ๐Ÿคซ

โ€‹Starlight by Astro โ†—๏ธ is a new project on Product Hunt, it is a web framework for building modern documentation websites.

  • Wanna learn the Design Principles and the psychology related to UX, check out growth.designโ†—๏ธ , where you will find a treasure trove of cool case studies.
  • A new AI model that you can prompt with UI designs, check it out hereโ†—๏ธ
  • A great collection of Transhuman doodles, check hereโ†—๏ธ
  • โ€‹Remix v2 Pre-release is outโ†—๏ธ . They are hiding v2 behind feature flags, which is quite neat.

The Frontend Developers Toolbox ๐Ÿงฐ

โ€‹

I hope you have a great day!

I write all my newsletters using Kit โ†—, my favorite newsletter platform.

Share this newsletter

Subscribe to the newsletter

Get the latest updates delivered directly to your inbox.