前情
Steemit 的几个前端项目(condenser, wallet, faucet)都使用了 redux 和 redux-saga。
这次升级 faucet 所有依赖库,发现新版本 redux 推荐使用官方的 @reduxjs/toolkit
工具集来实现 redux 的功能。
既然 redux 的官方推荐使用工具集,那么这次升级我们也要相对应的把原有的 redux 相关代码做改动。
其中,为了应对复杂的异步请求而引入的 redux-saga
,我不是很确定是否与工具集兼容,因此投入了时间来研究了一下。
创建 Redux Store: @reduxjs/toolkit
提供了 configureStore
来简化 store
的创建过程。你可以将 redux-saga
中间件添加到 store
中。
创建并运行 Saga 中间件: 使用 redux-saga
的 createSagaMiddleware
来创建 saga
中间件,然后将其添加到 configureStore
中。
运行你的 Saga
: 在 configureStore
创建 store
后,使用 sagaMiddleware.run
来启动你的 saga
。
下面是简单的例子。
store.js 文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
| // store.js import { configureStore } from '@reduxjs/toolkit'; import createSagaMiddleware from 'redux-saga'; import rootReducer from './reducers'; // 你的 reducer import rootSaga from './sagas'; // 你的 saga
// 创建 Saga 中间件 const sagaMiddleware = createSagaMiddleware();
// 配置 store 并添加 saga 中间件 const store = configureStore({ reducer: rootReducer, middleware: (getDefaultMiddleware) => getDefaultMiddleware().concat(sagaMiddleware), // 添加 saga 中间件 });
// 运行 rootSaga sagaMiddleware.run(rootSaga);
export default store;
|
saga.js 文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
| // sagas.js import { call, put, takeLatest } from 'redux-saga/effects'; import axios from 'axios';
// worker saga function* fetchUser(action) { try { const response = yield call(axios.get, `/api/user/${action.payload.userId}`); yield put({ type: 'USER_FETCH_SUCCESS', payload: response.data }); } catch (error) { yield put({ type: 'USER_FETCH_FAILURE', error: error.message }); } }
// watcher saga function* rootSaga() { yield takeLatest('USER_FETCH_REQUEST', fetchUser); }
export default rootSaga;
|
ET碎碎念,每周更新,欢迎订阅,点赞,转发!
data:image/s3,"s3://crabby-images/6a8f2/6a8f2bb427a5802762b1f6e358e13ef50d240e3f" alt=""
好用不贵的VPS推荐
https://1hour.win