xState is a snazzy way to manage JavaScript application state using visual state charts. It’s a pretty wonderful tool for making sure you think through every possible edge case of an application.
There’s also a handy visualiser tool that synchronizes your code and visuals. If you edit one, the other changes to match. ✨
data:image/s3,"s3://crabby-images/86cd7/86cd779f0560d56e92f6454756366e42f9b911ce" alt="Screenshot of the xState visualizer"
It’s perfect for visual thinkers. If someone could just build one of these for the entire of JavaScript I’ll be all set.
Here’s a little more illustrated detail on how this works:
data:image/s3,"s3://crabby-images/61edb/61edb56c33444aad79267948b499aac2521b481f" alt="Xstate is a tool that helps you plan out all the possible states in a JavaScript app"
data:image/s3,"s3://crabby-images/c0fcf/c0fcff8fc1661f6430e6f87bc2c42fd7bad3e0f7" alt="There's a handy interactive visualizer tool at xstate.js.org/viz"
data:image/s3,"s3://crabby-images/4d1e4/4d1e4e0c33ef365b3f40b4371295676d06a83d33" alt="A sequence of light bulbs swapping states between unlit, lit, dim, and broken."
data:image/s3,"s3://crabby-images/c080c/c080cf10eef77dd25527b98a0e468fcdd0725762" alt="We can add extra options onto our states such as actions, services, guards, and activities"
If you’re keen to learn more xState there’s two courses up on egghead that cover all the basics:
Want more illustrated notes on web development?
Take a look at Building VR Apps with React360 Building VR Apps with React360
Illustrated notes on building VR web apps with React360 , A Journey into Vue-Router A Journey into Vue-Router
Illustrated notes on how routing works in Vue.js , or Immutable Data with Immer and Personal Assistant Bots Immutable Data with Immer and Personal Assistant Bots
Illustrated notes on how work with immutable data in the Immer state library