use-valtio
Another custom hook to use Valtio proxy state
Install
npm install valtio use-valtio
Usage
import { proxy } from 'valtio/vanilla';
import { useValtio } from 'use-valtio';
const state = proxy({ count });
const Counter = () => {
const { count } = useValtio(state);
const inc = () => ++state.count;
return (
<div>
{count} <button onClick={inc}>+1</button>
</div>
);
};
But, why?
Valtio has useSnapshot
hook that can be used with proxy state,
which is similar to useValtio
.
import { useSnapshot } from 'valtio';
useSnapshot
is implemented with useSyncExternalStore
which is
a recommended way to use "external stores". It solves tearing issues.
However, the "Sync" behavior doesn't work nicely with concurrent rendering.
We can't use startTransition
as expected.
useValtio
doesn't use useSyncExternalStore
,
but only useReducer
and useEffect
.
It suffers from tearing, but works better with concurrent rendering.
After all, it's a trade-off.
There's a drawback (but it can be a benefit) with useValtio
.
Unlike useSnapshot
, useValtio
doesn't have usage tracking capability.
const state = proxy({ count: 0, text: 'hello' });
// This trigger re-renders if state.text changes
const { count } = useValtio(state);
// To mitigate it, it accepts path list
const count = useValtio(state, ['count']);
Examples
The examples folder contains working examples. You can run one of them with
PORT=8080 yarn run examples:01_typescript
and open http://localhost:8080 in your web browser.