redux 使用 redux-persist 进行数据持久化

2022-07-22 14:54:54 浏览数 (1)

0 1

redux-persist的介绍

在React项目中,我们会使用redux 来进行状态管理。redux和其它状态管理技术一样,刷新页面后,数据就会恢复成初始状态。

如何让数据实现持久化呢?大家应该都可想到了结合本地存储(localStorage 或 sessionStorage) 但每次的状态修改,都要去更改本地存储的数据工作量巨大,还容易出错。今天给大家推荐redux的一个插件redux-persist。redux-persist会将redux的store中的数据自动缓存到浏览器的 localStorage 中,不再需要单独去存储了。

0 2

redux-persist的使用

1、store.js 文件中的变化

首先,需要引入 persistStore, persistReducer

代码语言:javascript复制
import {persistStore, persistReducer} from 'redux-persist';

其次,执行persistReducer方法与persistStore方法,并行将persistStore方法的返回值导出

代码如下:

代码语言:javascript复制
import {createStore} from 'redux'
import reducers from '../reducers/index'
import {persistStore, persistReducer} from 'redux-persist';
import storage from 'redux-persist/lib/storage';
import autoMergeLevel2 from 'redux-persist/lib/stateReconciler/autoMergeLevel2';
const persistConfig = {
    key: 'root',
    storage: storage,
    stateReconciler: autoMergeLevel2 // 查看 'Merge Process' 部分的具体情况
}
const myPersistReducer = persistReducer(persistConfig, reducers)
const store = createStore(myPersistReducer)
export const persistor = persistStore(store)
export default store

2、在index.js中,将PersistGate标签嵌套在redux内层

代码语言:javascript复制
import React from 'react';
import ReactDOM from 'react-dom';
import {Provider} from 'react-redux'
import App from './App'
import store from './redux/store/store'
import {persistor} from './redux/store/store'
import {PersistGate} from 'redux-persist/lib/integration/react';
ReactDOM.render(<Provider store={store}>
            <PersistGate loading={null} persistor={persistor}>
               <App />
            </PersistGate>
        </Provider>, document.getElementById('root'));

3、最后,在浏览器中查看localStorage的值

你将发现数据已经存储到了localStorage中,刷新网页,redux中的数据也不会丢失

以上,就完成了使用redux-persist实现React持久化本地数据存储的简单应用

0 人点赞