React通过redux-persist持久化数据存储的方法示例


Posted in Javascript onFebruary 14, 2019

在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缓存数据

React通过redux-persist持久化数据存储的方法示例

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Js基础学习资料
Nov 23 Javascript
JavaScript中判断函数是new还是()调用的区别说明
Apr 07 Javascript
Struts2的s:radio标签使用及用jquery添加change事件
Apr 08 Javascript
Javascript实现滑块滑动改变值的实现代码
Apr 12 Javascript
flash+jQuery实现可关闭及重复播放的压顶广告
Apr 15 Javascript
JavaScript如何动态创建table表格
Aug 02 Javascript
深入浅析javascript中的作用域(推荐)
Jul 19 Javascript
基于JavaScript实现窗口拖动效果
Jan 18 Javascript
vue2.0设置proxyTable使用axios进行跨域请求的方法
Oct 19 Javascript
基于JavaScript实现五子棋游戏
Aug 26 Javascript
ng-alain表单使用方式详解
Jul 10 Javascript
微信小程序实现留言功能
Oct 31 Javascript
微信小程序实现简易table表格
Jun 19 #Javascript
微信小程序制作表格的方法
Feb 14 #Javascript
手把手带你封装一个vue component第三方库
Feb 14 #Javascript
微信小程序实现简单表格
Feb 14 #Javascript
手挽手带你学React之React-router4.x的使用
Feb 14 #Javascript
详解JavaScript原生封装ajax请求和Jquery中的ajax请求
Feb 14 #jQuery
vue中各种通信传值方式总结
Feb 14 #Javascript
You might like
哪吒敖丙传:新人物二哥敖乙出场 小敖丙奶气十足
2020/03/08 国漫
php ajax异步读取rss文档数据
2016/03/29 PHP
JS宝典学习笔记(下)
2007/01/10 Javascript
Js切换功能的简单方法
2010/11/23 Javascript
JS控制文本框textarea输入字数限制的方法
2013/06/17 Javascript
js this函数调用无需再次抓获id,name或标签名
2014/03/03 Javascript
JS给swf传参数的实现方法
2016/09/13 Javascript
AngularJS实现星星等级评分功能
2016/09/24 Javascript
jQuery实现移动端Tab选项卡效果
2017/03/15 Javascript
vue 计时器组件的实现代码
2017/09/14 Javascript
Mac中安装nvm的教程分享
2017/12/11 Javascript
详解关于微信setData回调函数中的坑
2019/02/18 Javascript
vue-cli3+typescript初体验小结
2019/02/28 Javascript
微信小程序缓存支持二次开发封装实现解析
2019/12/16 Javascript
vue.js+ElementUI实现进度条提示密码强度效果
2020/01/18 Javascript
关于vue-cli3打包代码后白屏的解决方案
2020/09/02 Javascript
Python中的高级数据结构详解
2015/03/27 Python
python遍历 truple list dictionary的几种方法总结
2016/09/11 Python
Python制作豆瓣图片的爬虫
2017/12/28 Python
python DataFrame获取行数、列数、索引及第几行第几列的值方法
2018/04/08 Python
详谈Numpy中数组重塑、合并与拆分方法
2018/04/17 Python
pyqt5 禁止窗口最大化和禁止窗口拉伸的方法
2019/06/18 Python
python turtle工具绘制四叶草的实例分享
2020/02/14 Python
解决python3插入mysql时内容带有引号的问题
2020/03/02 Python
CSS3实现复选框动画特效示例代码
2016/09/27 HTML / CSS
法律专业推荐信范文
2013/11/29 职场文书
校庆筹备方案
2014/03/30 职场文书
2014年入党积极分子党课学习心得体会模板
2014/04/03 职场文书
寄语是什么意思
2014/04/10 职场文书
优秀本科毕业生自荐信
2014/07/04 职场文书
生物工程专业求职信
2014/09/03 职场文书
企业投资意向书
2015/05/09 职场文书
PySwarms(Python粒子群优化工具包)的使用:GlobalBestPSO例子解析
2021/04/05 Python
python geopandas读取、创建shapefile文件的方法
2021/06/29 Python
windows11怎么查看wifi密码? win11查看wifi密码的技巧
2021/11/21 数码科技
win10搭建配置ftp服务器的方法
2022/08/05 Servers