博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
React通过redux-persist持久化数据存储
阅读量:6310 次
发布时间:2019-06-22

本文共 1539 字,大约阅读时间需要 5 分钟。

在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(
{/*网页内容*/}
, document.getElementById('root'));复制代码

这就完成了通过redux-persist实现React持久化本地数据存储的简单应用

3、最后我们调试查看浏览器中的localStorage缓存数据

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

转载地址:http://xsoxa.baihongyu.com/

你可能感兴趣的文章
python之基础篇(四)
查看>>
CentOS6.5 iscsi配置
查看>>
keras vgg16模型第一次使用注意事项
查看>>
rel=“prefetch”用法简单介绍
查看>>
SVG Path高级教程
查看>>
Java虚拟机工作原理详解 (一)
查看>>
创建错误日志循环
查看>>
文件查找命令find (笔记)
查看>>
「镁客·请讲」BeanVR秦凯:VR体验太孤独?我们要做娱乐性的社交产品
查看>>
图形化升级单机oracle 11.2.0.4 到 12.2.0.1
查看>>
[Linux]ubuntu开放server的指定端口
查看>>
bootstrap-列表组
查看>>
菜鸟学Linux 第024篇笔记 压缩,tar,read,script
查看>>
85、交换机安全MAC层攻击配置实验之Port-Security
查看>>
linux下启动SNMPD缺少 libsensors.so.3
查看>>
oracle临时表-优化查询速度
查看>>
css清除浮动的八大方法
查看>>
Windows开机改IP计划任务
查看>>
P6 550 #5802对5.3版本均有要求
查看>>
Vmware vSphere 6.0之安装 vCenter Server Appliance
查看>>