我有一个具有项目概念的网络应用程序。我正在使用react
,react-redux
和react-persist
withlocalForage
作为持久目标。
我现在正在尝试实现项目保存和项目加载功能,整个 Redux State 都作为一个项目文件。项目文件应作为用户下载保存到磁盘。和/或任何云文件存储服务。
保存部分是微不足道的,只需将存储,序列化为 JSON,然后将其发送给用户以供下载。
加载有点棘手,我ReactDOM.render
是相当平常的。
const {store, persistor} = configureStore()
ReactDOM.render(
<Provider store={store}>
<PersistGate loading={null} persistor={persistor}>
<Router>
<Route path={`${process.env.PATH}/`} component={App} />
</Router>
</PersistGate>
</Provider>,
document.getElementById('app')
)
如果已经创建了一个商店,configureStore()
则查找并返回它,否则它会创建一个新商店。
对于加载过程,我在想这样的事情会做
- 从用户加载 JSON 并解析
- 清除 localForage(因为它会覆盖 initalState)
- 使用用户提交的文件中的 initialState 重新创建商店
- 再次调用 ReactDOM.render()
redux
有没有更好的方法,也许是我在文档中错过的内置加载方法redux-persist
?