npm i redux-persist -S
// 在导出store的文件中配置加入代码(redux/store.js)
import { createStore } from 'redux';
import { persistStore, persistReducer } from 'redux-persist';
import storage from 'redux-persist/lib/storage';
import reducer from './reducer';
// WHITELIST: 白名单
const persistConfig = {
key: 'root',
storage: storage
whitelist: ['user'] // 需要缓存的白名单,不设置则全部缓存
};
const persistedReducer = persistReducer(persistConfig, reducer);
const store = createStore(persistedReducer);
export const persistor = persistStore(store);
export default store;
import React from 'react'
import ReactDOM from 'react-dom'
import { BrowserRouter as Router, Routes, Route } from 'react-router-dom'
import { Provider } from 'react-redux'
import { PersistGate } from 'redux-persist/lib/integration/react'
import store, { persistor } from './redux/store'
import App from './App'
ReactDOM.render(
<Provider store={store}>
<PersistGate loading={null} persistor={persistor}>
<Router>
<Routes>
<Route path="/*" element={<App />}></Route>
</Routes>
</Router>
</PersistGate>
</Provider>,
document.getElementById('root')
)
const userReducer = (state = userState, action) => {
const { type, payload = {} } = action
switch (type) {
case LOGIN:
return { ...state, ...payload }
default:
return state
}
}