Working with nested state

TLDR: Before xoid:

setState((state) => {
deeply: {
nested: {
value: state.deeply.nested.value + 1

after xoid:

atom.focus(s => s.deeply.nested.value).update(s => s + 1)

xoid makes it easier to work with nested state. Redux and React (and xoid) are based on immutable updates. Immutability is great, however it has by-products such as the excessive usage of the spread operator and others.

To overcome this, there are other tools like immutablejs or immer. Even Redux Toolkit comes with immer by default. Note that using Redux toolkit means adding another ~11kB to your bundle size. This number is ~5kB for immer alone. xoid is ~1kB, yet it can handle that.


To see how xoid compares to a classical reducer, and a dedicated library that's using immer internally, you can check the following example:

Last updated on