useStore is a React hook that allows using a Svelte Store in a React component.
import { useStore } from "svelte-preprocess-react";
const userStore = writable({ name: "John Doe" });
const UserGreet: React.FC = () => {
const $user = useStore(userStore);
return <h1>Hello, {$user.name}</h1>;
};
export default UserGreet;
When the Svelte Store is updated the component will rerender and receive the new value from the useStore hook.
Inside a Svelte component $user = { name:'Jane Doe' }
or $user.name = 'Jane Doe'
will trigger an update.
In React and other regular javascript files this does not work.
To update the value and trigger an update use the set
or update
methods:
// Instead of `$user = { name:'Jane Doe' }`
user.set({ name: "Jane Doe" });
// Instead of `$user.name = 'Jane Doe'`
user.update((user) => ({ ...user, name: "Jane Doe" }));
See https://svelte.dev/docs#run-time-svelte-store for more information.