ZustandFor the client we prefer to use Zustand as it is a small bear bones state management solution which is straight forward to use. We are slowly switching from using Redux to using Zustand where this is possible.The reason being, is we believe, it is far more simpler and intuitive. Setting up Zustand is easy and using it is even more easier!Hopefully this example will demonstrate this. There are four components here. Each is 'using' the CounterStore which is a Zustand store. If you click the 'Increase' button in the CounterIncrease.tsx component, the counter will increase by one as expected. But only the CounterDisplay.tsx component will be re-rendered as no states have changed in the other components. Note that if the counter is already 5, clicking the 'SetBy (5)' won't re-render anything.CounterDisplay.tsx0CounterSetBy.tsxCounterIncrease.tsxCounterDecrease.tsxThese are the corresponding code for each of the four componentsAnd this is the code for the storeAs you can see, it is extremely easy to setup and use. The boilerplate is massively reduced compared to alternatives like Redux.
For the client we prefer to use as it is a small bear bones state management solution which is straight forward to use. We are slowly switching from using Redux to using Zustand where this is possible.
Zustand
The reason being, is we believe, it is far more simpler and intuitive. Setting up Zustand is easy and using it is even more easier!
Hopefully this example will demonstrate this. There are four components here. Each is 'using' the CounterStore which is a Zustand store. If you click the 'Increase' button in the CounterIncrease.tsx component, the counter will increase by one as expected. But only the CounterDisplay.tsx component will be re-rendered as no states have changed in the other components. Note that if the counter is already 5, clicking the 'SetBy (5)' won't re-render anything.
CounterDisplay.tsx
0
CounterSetBy.tsx
CounterIncrease.tsx
CounterDecrease.tsx
These are the corresponding code for each of the four components
And this is the code for the store
As you can see, it is extremely easy to setup and use. The boilerplate is massively reduced compared to alternatives like Redux.