在 Redux 中保持状态的一种方法是使用 Redux Persist 库。这个库可以帮助您保持状态在不同路由之间的同步。可以通过将状态存储在本地存储或异步存储中来实现这一点。
在您的 App.js 中,您需要使用 redux-persist 来导入 createStore 和 persistReducer。persistReducer 是 Redux Persist 的一个高阶函数,它可以处理 Redux Reducer 并将状态转换为 JSON。
import { createStore } from 'redux';
import { persistReducer } from 'redux-persist';
import storage from 'redux-persist/lib/storage'; // defaults to localStorage for web
import rootReducer from './reducers';
const persistConfig = {
key: 'root',
storage,
};
const persistedReducer = persistReducer(persistConfig, rootReducer);
export default () => {
let store = createStore(persistedReducer);
let persistor = persistStore(store);
return { store, persistor };
};
然后在 index.js 文件中,我们需要将 Provider 对象和 PersistGate 对象包装在应用程序之外,以确保我们的 Redux 状态保持同步:
import { Provider } from 'react-redux';
import { PersistGate } from 'redux-persist/lib/integration/react';
import configureStore from './configureStore';
import App from './App';
const { store, persistor } = configureStore();
ReactDOM.render(
,
document.getElementById('root')
);
现在,您的 Redux 状态将在应用程序中保持同步,而不管您切换到哪个路由。如果需要从 Redux 状态中提取多个部分,可以通过将他们定义为嵌套对象或数组的形式来进行配置。