avatar

How to manage a list of refs using a ref callback

Sometimes you might need a ref to each item in the list, and you don’t know how many you will have.

One possible way around this is to get a single ref to their parent element, and then use DOM manipulation methods like querySelectorAll to find the individual child nodes from it. However, this is brittle and can break if your DOM structure changes.

Another solution is to pass a function to the ref attribute. This is called a ref callback. React will call your ref callback with the DOM node when it's time to set the ref, and with null when it's time to clear it. This lets you maintain your own array or a map, and access any ref by its index or some kind of ID.

<li
  key={cat.id}
  ref={node => {
    const map = getMap();
    if (node) {
      // Add to the Map
      map.set(cat.id, node);
    } else {
      // Remove from the Map
      map.delete(cat.id);
    }
  }}
>