我有这样的效果,请求从服务中检索产品的几个值。调度REQUEST_PRODUCTS按预期调用一次,但是当我尝试转到路由中的其他位置时,会调用this.apiMarketServices几次,这会触发路由器导航,这将重定向到上一页。 REQUEST_PRODUCTS操作被调度一次。为什么这种效应被称为几次?
我是否需要在效果中添加某种停止以避免在返回GetSuccess和GetFailed之后调用?
@Effect()
requestProductsFromMarket = this.actions$
.ofType(REQUEST_PRODUCTS)
.withLatestFrom(this.store)
.switchMap(([action, store]) => {
const id = store.product.id;
return this.savedProducts.getProduct(id, 'store');
})
.switchMap(_ => this.stateService.getMarketId())
.switchMap(({ marketId }) =>
this.apiMarketServices.get(MARKETS_PROFILES + marketId)
)
.withLatestFrom(this.store)
.map(([r, store]) => {
const ser = r.data.map(s => s.legId);
const storSer =
store.product.serIds;
if (storSer.every(s =>ser.includes(s))) {
this.router.navigate([
`/products/edit/${store.products.id}`
]);
return GetSuccess;
} else {
return GetFailed;
}
})
.catch(() => of(GetQueryFailed));
缺陷的解决方案与Observable有关。在调试中多次调用“this.apiMarketServices.get(MARKETS_PROFILES + marketId)”,我将此服务作为缺陷的原因进行了调整:
.switchMap(({ marketId }) =>
this.apiMarketServices.get(MARKETS_PROFILES + marketId)
)
但真正的原因是stateSevice,这个行为主题在应用程序的其他部分用next更新了。
.switchMap(_ => this.stateService.getMarketId())
为了避免这些调用,我创建了一个函数,以便从BehaviorSubject中检索当前值。
getCurrentMarketId(): ClientData {
return this.currentMarket.value; // BehaviorSubject
}
我添加了这个函数,调用每次调度效果一次。
...
.switchMap(([action, store]) => {
const id = store.product.id;
return this.savedProducts.getProduct(id, 'store');
})
.map(_ => this.stateService.getCurrentMarketId())
.switchMap(({ marketId }) =>
this.apiMarketServices.get(MARKETS_PROFILES + marketId)
)