jotai
Compare original and translation side by side
🇺🇸
Original
English🇨🇳
Translation
Chinese@json-render/jotai
@json-render/jotai
Jotai adapter for json-render's interface. Wire a Jotai atom as the state backend for json-render.
StateStore适配json-render的接口的Jotai适配器,可将Jotai atom绑定为json-render的状态后端。
StateStoreInstallation
安装
bash
npm install @json-render/jotai @json-render/core @json-render/react jotaibash
npm install @json-render/jotai @json-render/core @json-render/react jotaiUsage
使用方法
tsx
import { atom } from "jotai";
import { jotaiStateStore } from "@json-render/jotai";
import { StateProvider } from "@json-render/react";
// 1. Create an atom that holds the json-render state
const uiAtom = atom<Record<string, unknown>>({ count: 0 });
// 2. Create the json-render StateStore adapter
const store = jotaiStateStore({ atom: uiAtom });
// 3. Use it
<StateProvider store={store}>
{/* json-render reads/writes go through Jotai */}
</StateProvider>tsx
import { atom } from "jotai";
import { jotaiStateStore } from "@json-render/jotai";
import { StateProvider } from "@json-render/react";
// 1. 创建承载json-render状态的atom
const uiAtom = atom<Record<string, unknown>>({ count: 0 });
// 2. 创建json-render StateStore适配器
const store = jotaiStateStore({ atom: uiAtom });
// 3. 使用适配器
<StateProvider store={store}>
{/* json-render的读写操作都会通过Jotai执行 */}
</StateProvider>With a Shared Jotai Store
配合共享Jotai Store使用
When your app already uses a Jotai with a custom store, pass it so both json-render and your components share the same state:
<Provider>tsx
import { atom, createStore } from "jotai";
import { Provider as JotaiProvider } from "jotai/react";
import { jotaiStateStore } from "@json-render/jotai";
import { StateProvider } from "@json-render/react";
const jStore = createStore();
const uiAtom = atom<Record<string, unknown>>({ count: 0 });
const store = jotaiStateStore({ atom: uiAtom, store: jStore });
<JotaiProvider store={jStore}>
<StateProvider store={store}>
{/* Both json-render and useAtom() see the same state */}
</StateProvider>
</JotaiProvider>当你的应用已经通过自定义store使用了Jotai 时,传入该store即可让json-render和你的组件共享同一份状态:
<Provider>tsx
import { atom, createStore } from "jotai";
import { Provider as JotaiProvider } from "jotai/react";
import { jotaiStateStore } from "@json-render/jotai";
import { StateProvider } from "@json-render/react";
const jStore = createStore();
const uiAtom = atom<Record<string, unknown>>({ count: 0 });
const store = jotaiStateStore({ atom: uiAtom, store: jStore });
<JotaiProvider store={jStore}>
<StateProvider store={store}>
{/* json-render和useAtom()都能读取到同一份状态 */}
</StateProvider>
</JotaiProvider>API
API
jotaiStateStore(options)
jotaiStateStore(options)jotaiStateStore(options)
jotaiStateStore(options)Creates a backed by a Jotai atom.
StateStore| Option | Type | Required | Description |
|---|---|---|---|
| | Yes | A writable atom holding the state model |
| Jotai | No | The Jotai store instance. Defaults to a new store. Pass your own to share state with |
创建一个由Jotai atom驱动的。
StateStore| 选项 | 类型 | 必填 | 描述 |
|---|---|---|---|
| | 是 | 用于存储状态模型的可写atom |
| Jotai | 否 | Jotai store实例,默认创建新store。如需与 |