在react项目中,我们经常会通过redux以及react-redux来存储和管理全局数据。但是通过redux存储全局数据时,会有这么一个问题,如果用户刷新了网页,那么我们通过redux存储的全局数据就会被全部清空,比如登录信息等。
这个时候,我们就会有全局数据持久化存储的需求。首先我们想到的就是localstorage,localstorage是没有时间限制的数据存储,我们可以通过它来实现数据的持久化存储。
但是在我们已经使用redux来管理和存储全局数据的基础上,再去使用localstorage来读写数据,这样不仅是工作量巨大,还容易出错。那么有没有结合redux来达到持久数据存储功能的框架呢?当然,它就是redux-persist。redux-persist会将redux的store中的数据缓存到浏览器的localstorage中。
redux-persist的使用
1、对于reducer和action的处理不变,只需修改store的生成代码,修改如下
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标签作为网页内容的父标签
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持久化本地数据存储的简单应用
3、最后我们调试查看浏览器中的localstorage缓存数据
发现数据已经存储到了localstorage中,此时刷新网页,redux中的数据也不会丢失
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。
如对本文有疑问, 点击进行留言回复!!
Android 入门第七讲01-数据存储(数据存储概述,文件存储(raw和asserts目录读写,data/data/包名目录读写,sdcard目录读写),SharedPreferences读写)
vue-axios系列:axios拦截器,配置请求头,配置请求参数
Vuejs 针对 安卓低版本 、ios9.x 不兼容 ES6语法导致失效解决方法
网友评论