在React项目中,咱们常常会经过redux以及react-redux来存储和管理全局数据。可是经过redux存储全局数据时,会有这么一个问题,若是用户刷新了网页,那么咱们经过redux存储的全局数据就会被所有清空,好比登陆信息等。react
这个时候,咱们就会有全局数据持久化存储的需求。首先咱们想到的就是localStorage,localStorage是没有时间限制的数据存储,咱们能够经过它来实现数据的持久化存储。redux
可是在咱们已经使用redux来管理和存储全局数据的基础上,再去使用localStorage来读写数据,这样不只是工做量巨大,还容易出错。那么有没有结合redux来达到持久数据存储功能的框架呢?固然,它就是redux-persist。redux-persist会将redux的store中的数据缓存到浏览器的localStorage中。浏览器
redux-persist的使用缓存
一、对于reducer和action的处理不变,只需修改store的生成代码,修改以下bash
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
复制代码
二、在index.js中,将PersistGate标签做为网页内容的父标签框架
import React from 'react';
import ReactDOM from 'react-dom';
import {Provider} from 'react-redux'
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}>
{/*网页内容*/}
</PersistGate>
</Provider>, document.getElementById('root'));
复制代码
这就完成了经过redux-persist实现React持久化本地数据存储的简单应用dom
三、最后咱们调试查看浏览器中的localStorage缓存数据ide
发现数据已经存储到了localStorage中,此时刷新网页,redux中的数据也不会丢失ui