As someone who has been using React for +10 years, I've seen many State Management libraries come and go. Three years ago, I decided to keep things si

React State Management: Going beyond useState after 3 years! | Michael Yagudaev

submited by
Style Pass
2024-08-07 18:30:16

As someone who has been using React for +10 years, I've seen many State Management libraries come and go. Three years ago, I decided to keep things simple and only use what react offers that is: useState, useEffect and useRef with a splash of useContext when needed.

However, I started building an Animation Timeline Player for Figma and that required more complex UI state than I've encountered before. Take a look 👀👇

⌨️ Keyboard shortcuts (arrow keys + space bar + shift) 🖱️ Mouse clicking and scrubbing 📍 Buttons play/pause and reset

Between the useState, useRef and useEffect in this custom hook it was very hard to follow the logic and there were subtle bugs with the state. The issues were due to stale data usually as the state of all 4 of the variables at the top depend on each other.

In this case, since we are using it as an animation timer and an isPlaying state we need to get the latest state each time. Stale state will cause us to execute the wrong logic and have bugs 🐞.

Leave a Comment