当前位置:   article > 正文

React通过redux-persist持久化数据存储

react 持久化

React项目中,我们经常会通过redux以及react-redux来存储和管理全局数据。但是通过redux存储全局数据时,会有这么一个问题,如果用户刷新了网页,那么我们通过redux存储的全局数据就会被全部清空,比如登录信息等。

这个时候,我们就会有全局数据持久化存储的需求。首先我们想到的就是localStorage,localStorage是没有时间限制的数据存储,我们可以通过它来实现数据的持久化存储。

但是在我们已经使用redux来管理和存储全局数据的基础上,再去使用localStorage来读写数据,这样不仅是工作量巨大,还容易出错。那么有没有结合redux来达到持久数据存储功能的框架呢?当然,它就是redux-persist。redux-persist会将redux的store中的数据缓存到浏览器的localStorage中。

redux-persist的使用

1、对于reducer和action的处理不变,只需修改store的生成代码,修改如下

  1. import {createStore} from 'redux'
  2. import reducers from '../reducers/index'
  3. import {persistStore, persistReducer} from 'redux-persist';
  4. import storage from 'redux-persist/lib/storage';
  5. import autoMergeLevel2 from 'redux-persist/lib/stateReconciler/autoMergeLevel2';
  6. const persistConfig = {
  7. key: 'root',
  8. storage: storage,
  9. stateReconciler: autoMergeLevel2 // 查看 'Merge Process' 部分的具体情况
  10. };
  11. const myPersistReducer = persistReducer(persistConfig, reducers)
  12. const store = createStore(myPersistReducer)
  13. export const persistor = persistStore(store)
  14. export default store

2、在index.js中,将PersistGate标签作为网页内容的父标签

  1. import React from 'react';
  2. import ReactDOM from 'react-dom';
  3. import {Provider} from 'react-redux'
  4. import store from './redux/store/store'
  5. import {persistor} from './redux/store/store'
  6. import {PersistGate} from 'redux-persist/lib/integration/react';
  7. ReactDOM.render(<Provider store={store}>
  8. <PersistGate loading={null} persistor={persistor}>
  9. {/*网页内容*/}
  10. </PersistGate>
  11. </Provider>, document.getElementById('root'));

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

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

localStorage.png

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Cpp五条/article/detail/510719
推荐阅读
相关标签
  

闽ICP备14008679号