React通過redux-persist持久化數據存儲


在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中的數據也不會丟失

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM