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 相关文章推荐
document对象execCommand的command参数介绍
Aug 01 Javascript
javascript setTimeout()传递函数参数(包括传递对象参数)
Apr 07 Javascript
23个超流行的jQuery相册插件整理分享
Apr 25 Javascript
js控制淡入淡出示例代码
Nov 12 Javascript
VueJs路由跳转——vue-router的使用详解
Jan 10 Javascript
js replace()去除代码中空格的实例
Feb 14 Javascript
Cropper.js 实现裁剪图片并上传(PC端)
Aug 20 Javascript
一文让你彻底搞清楚javascript中的require、import与export
Sep 24 Javascript
JavaScript实现带有子菜单和控件的slider轮播图效果
Nov 01 Javascript
在移动端使用vue-router和keep-alive的方法示例
Dec 02 Javascript
详解将微信小程序接口Promise化并使用async函数
Aug 05 Javascript
JS addEventListener()和attachEvent()方法实现注册事件
Jan 11 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代码
2012/07/14 PHP
php+ajax无刷新分页实例详解
2015/12/07 PHP
PHP调用其他文件中的类
2018/04/02 PHP
PHP实现文字写入图片功能
2019/02/18 PHP
php菜单/评论数据递归分级算法的实现方法
2019/08/01 PHP
JavaScript创建命名空间(namespace)的最简实现
2007/12/11 Javascript
google地图的路线实现代码
2009/08/20 Javascript
IE中createElement需要注意的一个问题
2010/07/13 Javascript
客户端限制只能上传jpg格式图片的js代码
2010/12/09 Javascript
javascript ajax的5种状态介绍
2014/08/18 Javascript
nodejs npm package.json中文文档
2014/09/04 NodeJs
深入理解JavaScript系列(38):设计模式之职责链模式详解
2015/03/04 Javascript
无刷新上传文件并返回自定义值
2015/06/11 Javascript
jQuery+HTML5加入购物车代码分享
2020/10/29 Javascript
JS中Swiper的使用和轮播图效果
2017/08/11 Javascript
微信小程序调用摄像头隐藏式拍照功能
2018/08/22 Javascript
Vue实现简单的拖拽效果
2020/08/25 Javascript
antd的select下拉框因为数据量太大造成卡顿的解决方式
2020/10/31 Javascript
python 判断一个进程是否存在
2009/04/09 Python
自动化Nginx服务器的反向代理的配置方法
2015/06/28 Python
PyQt5每天必学之组合框
2018/04/20 Python
pygame游戏之旅 python和pygame安装教程
2018/11/20 Python
Python中按键来获取指定的值
2019/03/02 Python
Django框架实现的普通登录案例【使用POST方法】
2019/05/15 Python
python读取与处理netcdf数据方式
2020/02/14 Python
如何利用python之wxpy模块玩转微信
2020/08/17 Python
Python实现AES加密,解密的两种方法
2020/10/03 Python
美国领先的男士和女士内衣购物网站:Freshpair
2019/02/25 全球购物
高中生家长会演讲稿
2014/01/14 职场文书
煤矿安全承诺书
2014/05/22 职场文书
《周恩来的四个昼夜》观后思想汇报范文两篇
2014/09/10 职场文书
公安机关党的群众路线教育实践活动剖析材料
2014/10/10 职场文书
2014年人民警察入党思想汇报
2014/10/12 职场文书
税务会计岗位职责
2015/04/02 职场文书
暑期社会实践新闻稿
2015/07/17 职场文书
详解Java实践之抽象工厂模式
2021/06/18 Java/Android