为什么在调用动作后我的效果会多次运行?

问题描述 投票:0回答:1

我有这样的效果,请求从服务中检索产品的几个值。调度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));
javascript angular ngrx ngrx-effects
1个回答
0
投票

缺陷的解决方案与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)
 )
© www.soinside.com 2019 - 2024. All rights reserved.