React通過redux-persist持久化資料儲存

RaoMeng發表於2019-02-22

在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.png

發現資料已經儲存到了localStorage中,此時重新整理網頁,redux中的資料也不會丟失

相關文章