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 相关文章推荐
javascript 面向对象全新理练之数据的封装
Dec 03 Javascript
JavaScript 嵌套函数指向this对象错误的解决方法
Mar 15 Javascript
Js setInterval与setTimeout(定时执行与循环执行)的代码(可以传入参数)
Jun 11 Javascript
基于jquery的实现简单的表格中增加或删除下一行
Aug 01 Javascript
JavaScript ( (__ = !$ + $)[+$] + ({} + $)[_/_] +({} + $)[_/_] )
Feb 25 Javascript
jQuery链式操作如何实现以及为什么要用链式操作
Jan 17 Javascript
js实现黑色简易的滑动门网页tab选项卡效果
Aug 31 Javascript
JS简单实现String转Date的方法
Mar 02 Javascript
Bootstrap3.0建站教程(一)之bootstrap表单元素排版
Jun 01 Javascript
Javascript之面向对象--方法
Dec 02 Javascript
js实现选项卡内容切换以及折叠和展开效果【推荐】
Jan 08 Javascript
JS实现利用两个队列表示一个栈的方法
Dec 13 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
php使用ob_start()实现图片存入变量的方法
2014/11/14 PHP
PHP连接MySQL数据的操作要点
2015/03/20 PHP
PHP获取指定日期是星期几的实现方法
2016/11/30 PHP
iis6手工创建网站后无法运行php脚本的解决方法
2017/06/08 PHP
TNC vs BOOM BO3 第三场2.13
2021/03/10 DOTA
小型js框架veryide.librar源代码
2009/03/05 Javascript
使用百度地图api实现根据地址查询经纬度
2014/12/11 Javascript
jQuery中is()方法用法实例
2015/01/06 Javascript
JQuery判断radio(单选框)是否选中和获取选中值方法总结
2015/04/15 Javascript
jQuery实现订单提交页发送短信功能前端处理方法
2016/07/04 Javascript
浅析script标签中的defer与async属性
2016/11/30 Javascript
利用Javascript开发一个二维周视图日历
2017/12/14 Javascript
微信小程序时间控件picker view使用详解
2018/12/28 Javascript
Vue源码解析之数据响应系统的使用
2019/04/24 Javascript
vue 使用element-ui中的Notification自定义按钮并实现关闭功能及如何处理多个通知
2019/08/17 Javascript
详解用js代码触发dom事件的实现方案
2020/06/10 Javascript
[49:59]KG vs Mineski 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/16 DOTA
详解python实现线程安全的单例模式
2018/03/05 Python
Python列表生成式与生成器操作示例
2018/08/01 Python
使用python获取电脑的磁盘信息方法
2018/11/01 Python
10 分钟快速入门 Python3的教程
2019/01/29 Python
python tkinter库实现气泡屏保和锁屏
2019/07/29 Python
Python Print实现在输出中插入变量的例子
2019/12/25 Python
从多个tfrecord文件中无限读取文件的例子
2020/02/17 Python
django实现后台显示媒体文件
2020/04/07 Python
基于Python下载网络图片方法汇总代码实例
2020/06/24 Python
自定义html标记替换html5新增元素
2008/10/17 HTML / CSS
美国家具网站:Cymax
2016/09/17 全球购物
行政管理毕业生自荐信
2014/02/24 职场文书
会计个人实习计划书
2014/08/15 职场文书
淮阳太昊陵导游词
2015/02/10 职场文书
2015年招商引资工作总结
2015/04/25 职场文书
幼儿园六一主持词开场白
2015/05/28 职场文书
无房证明样本
2015/06/17 职场文书
蓝天保卫战收官在即 :15行业将开展环保分级评价
2019/07/19 职场文书
详细介绍python操作RabbitMq
2022/04/12 Python