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

在React項目中,咱們常常會經過redux以及react-redux來存儲和管理全局數據。可是經過redux存儲全局數據時,會有這麼一個問題,若是用戶刷新了網頁,那麼咱們經過redux存儲的全局數據就會被所有清空,好比登陸信息等。react

這個時候,咱們就會有全局數據持久化存儲的需求。首先咱們想到的就是localStorage,localStorage是沒有時間限制的數據存儲,咱們能夠經過它來實現數據的持久化存儲。redux

可是在咱們已經使用redux來管理和存儲全局數據的基礎上,再去使用localStorage來讀寫數據,這樣不只是工做量巨大,還容易出錯。那麼有沒有結合redux來達到持久數據存儲功能的框架呢?固然,它就是redux-persist。redux-persist會將redux的store中的數據緩存到瀏覽器的localStorage中。瀏覽器

redux-persist的使用緩存

一、對於reducer和action的處理不變,只需修改store的生成代碼,修改以下bash

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

複製代碼

二、在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持久化本地數據存儲的簡單應用dom

三、最後咱們調試查看瀏覽器中的localStorage緩存數據ide

localStorage.png

發現數據已經存儲到了localStorage中,此時刷新網頁,redux中的數據也不會丟失ui

相關文章
相關標籤/搜索