我正在苦苦挣扎redux-observable
,试图弄清楚如何用这个流程创建史诗:
- 听一个
GET_ITEMS_REQUEST
动作 - 发送 HTTP 请求以获取一些项目
- 获取这些项目的 ID 并发送一个
GET_ITEM_DETAILS_REQUEST
操作,该操作将发送另一个 HTTP 请求以获取这些项目的更多详细信息 - 用第二个请求中的细节装饰第一个请求中的项目并发送最终
GET_ITEMS_SUCCESS
操作,这将更新 redux 状态
从第 3 步到第 4 步是我卡住的地方。我知道如何GET_ITEM_DETAILS_REQUEST
使用项目 ID 进行调度,但我不知道如何侦听/订阅GET_ITEM_DETAILS_REQUEST
操作以获取项目详细信息响应。
到目前为止,我有以下内容:
function getItemsEpic(action$) {
return action$
// step 1
.ofType('GET_ITEMS_REQUEST')
.mergeMap(() => {
// step 2
return Observable.from(Api.getItems())
})
.mergeMap((items) => {
// step 3
const itemIds = items.map((item) => item.id);
return Observable.of({
type: 'GET_ITEM_DETAILS_REQUEST',
ids: itemIds
});
})
// ... what now?
.catch(() => {
return Observable.of({
type: 'GET_ITEMS_FAILURE'
});
});
}