如何从订阅另一个函数的observable的函数返回布尔值?

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

我有这个问题,我有一个ProductService有一个布尔函数validateProductsBeforeChanges

validateProductsBeforeChanges里面,我从另一个名为OrderService的服务中调用一个函数,它返回一个observable。

一些示例代码:

validateProductsBeforeChanges(idProduct): Boolean {
     this._orderService.getAll()
         .subscribe(orders => {
               this.orders = orders;
               this.ordersWithCurrentMenu = this.orders.filter(x => 
                                                               x.products.find(y => y.code == idProduct));

               if(this.ordersWithCurrentMenu.length > 0) {
                   return false;
               }
               else {
                   return true;
               }
         });
}

问题是vs代码抛出语法错误:

声明类型既不是'void'也不是'any'的函数必须返回一个值

所以我尝试做这样的事情:

validateProductsBeforeChanges(idProduct): Boolean {
     this._orderService.getAll()
         .subscribe(orders => {
              this.orders = orders;
              this.ordersWithCurrentMenu = this.orders.filter(x => x.products.find(y => y.code == idProduct));

              if (this.ordersWithCurrentMenu.length > 0) {
                  return false;
              }
              else {
                  return true;
              }
         });

    return false;
}

但是在这种情况下,最后一个返回在.subcribe结束之前执行,并且函数总是返回false。

关于如何解决这个问题的任何想法?

非常感谢你!

angular typescript service angular5 observable
1个回答
1
投票

像这样的东西:

validateProductsBeforeChanges(idProduct): Observable<Boolean>{
  return this._orderService.getAll()
  .pipe(
      map(orders => 
       orders.filter(x => x.products.find(y => y.code == idProduct))
             .map(filtered => filtered <= 0)
      )          
   );
}

使用这样:

validateProductsBeforeChanges(id).subscribe(t=> {
     if (t) {
        ...
     }
     else {
       ...
     }
})
© www.soinside.com 2019 - 2024. All rights reserved.