React通过redux-persist持久化数据存储
2023-09-11 14:15:29 时间
在React项目中,我们经常会通过redux以及react-redux来存储和管理全局数据。但是通过redux存储全局数据时,会有这么一个问题,如果用户刷新了网页,那么我们通过redux存储的全局数据就会被全部清空,比如登录信息等。
这个时候,我们就会有全局数据持久化存储的需求。首先我们想到的就是localStorage,localStorage是没有时间限制的数据存储,我们可以通过它来实现数据的持久化存储。
但是在我们已经使用redux来管理和存储全局数据的基础上,再去使用localStorage来读写数据,这样不仅是工作量巨大,还容易出错。那么有没有结合redux来达到持久数据存储功能的框架呢?当然,它就是redux-persist。redux-persist会将redux的store中的数据缓存到浏览器的localStorage中。
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中的数据也不会丢失
相关文章
- (尚030)Vue_案例_存储数据(localStorage本地存储技术)
- HBase-存储-写路径
- Android开发之利用SQLite进行数据存储
- 华为python机试题目:明明的随机数、汽水瓶、求int型正整数在内存中存储时1的个数、取近似值、蛇形矩阵、数据分类处理、数字颠倒
- Avere:颠覆数据存储的新模式
- Ceph分布式存储学习指南1.8 Ceph与其他存储解决方案
- 【C数据存储】整型在内存中的存储(进阶版)
- Spring Cloud Alibaba基础教程:Sentinel使用Nacos存储规则
- 《好学的C++程序设计》——第2章 对基本数据分类存储和访问
- Swift - 使用Core Data进行数据持久化存储
- 黑极空间:微软计划使用DNA存储数据
- Docker底层:Docker 卷与持久化数据存储的底层原理
- 【12.2新特性】在Oracle Active Data Guard上部署列式存储
- 云存储与视频监控协力合作 平安城市再提速
- Graph database_neo4j 底层存储结构分析(5)
- Unity 之 转微信小游戏本地数据存储方法分享
- (3.6)sql server存储引擎--文件与数据页及数据行的结构
- 存储涨价不止:问存储行业到底怎么了?
- Scrapy爬虫(七):爬虫数据存储实例
- [转]SqlServer中Sql查看存储过程
- IBM公司存储营收继续保持稳定表现——四年来不断下跌