您好,登錄后才能下訂單哦!
在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緩存數據
發現數據已經存儲到了localStorage中,此時刷新網頁,redux中的數據也不會丟失
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。