在最近的一个项目中,要求对 redux 数据作持久化处理,通过研究后成功实现,在此记录一下过程react
咱们能够使用 redux-persist
对数据作持久化处理git
npm i --save redux-persist
安装成功后,咱们须要对 store
代码进行修改,这是个人 store 生成文件github
import {applyMiddleware, createStore, compose} from 'redux'; import {createLogger} from 'redux-logger'; import thunk from 'redux-thunk'; import reducers from '../reducers'; import {persistStore, persistReducer} from 'redux-persist'; import storage from 'redux-persist/lib/storage' const persistConfig = { key: 'milk', # 对于数据 key 的定义 storage, # 选择的存储引擎 } # 对 reducers 的封装处理 const persistedReducer = persistReducer(persistConfig, reducers) let loggerMiddleware = createLogger(); export default function configureStore() { const enhancers = compose( applyMiddleware(thunk, loggerMiddleware), ); # 处理后的 reducers 须要做为参数传递在 createStore 中 const store = createStore(persistedReducer, enhancers) # 持久化 store let persistor = persistStore(store) return {store, persistor} }
在 react-native 中,存储引擎默认为 AsyncStorage
Android是以key=>value的形式存储在本地sqlite中
iOS 是直接存沙盒文件
sql
其中还有不少能够配置的地方,你们自行参考官方文档npm
修改完生成 store 代码后,在入口文件作一次修改,须要引入 PersistGate
来进行二次的组装redux
import React, {Component} from 'react'; import {Provider} from 'react-redux'; import HomeContainer from './container/HomeContainer' import configureStore from './redux/store' import {PersistGate} from 'redux-persist/integration/react' # 看这里 const {store, persistor} = configureStore(); class App extends Component { render() { return ( <Provider store={store}> <PersistGate loading={null} persistor={persistor}> <HomeContainer/> </PersistGate> </Provider> ); } } export default App
简单配置便可,咱们能够看一下效果react-native