/use-valtio

Another custom hook to use Valtio proxy state

Primary LanguageTypeScriptMIT LicenseMIT

use-valtio

CI npm size discord

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.

You can also try them in codesandbox.io: 01 02