ngrx效果-具有相同效果的两个http api

时间:2020-05-20 08:52:29

标签: angular typescript ngrx ngrx-store ngrx-effects

我具有以下效果,使用update api更新对象的一部分(此api返回对象的id),然后使用findById api获得整个对象我将api更新的结果作为参数传递,问题是我第一次进行更新时,findById api知道更新已完成,却返回了没有更新的对象

@Effect()
updateScopeCoverage$ = this.actions$.pipe(
    ofType<networksActions.PatchScopeCoverage>(networksActions.NetworkActionTypes.PATCH_SCOPE_COVERAGE),
    map(action => action.payload),
    exhaustMap(scopeCoverage => this.apiNetwork.update({ updateScopeCoverageRequest: scopeCoverage }).pipe(
        switchMap(id => this.apiNetwork.findById({ externalId: id }).pipe(
            map((network: Network) => new networksActions.PatchSuccess({
                id: network.externalId,
                changes: network
            })),
        )),
        catchError(err => {
            alert(err.message);
            return of(new networksActions.Failure({ concern: 'PATCH', error: err }));
        })
    ))
);


findById(args: { externalId: string }): Observable<models.Network> {
        const path = `/networks/v1.0/${args.externalId}`;
        return this.http.get<models.Network>(`${this.domain}${path}`);
}

1 个答案:

答案 0 :(得分:0)

如果我理解正确-后端返回旧数据,是否正确?因为效果看起来不错。它发送一个更新请求,等待响应,然后发送findById,等待并分派PatchSuccess操作。顺序正确。我会console.log什么后端返回,如果它返回旧数据-这意味着后端的缓存或复制。例如,尝试将delay(1000)放在switchMap(id => findById之前,如果可以,则100%出现后端问题。