Angular HTTP客户端可观察的管道图

时间:2018-10-29 16:35:26

标签: javascript angular rxjs

我有这个服务

  doSomething(): Observable<any> {
    return this.http.get('http://my.api.com/something')
      .pipe(
        map((data: Response) => {
            if (data && data['success'] && data['success'] === true) {
              return true;
            } else {
              return false;
            }
          }
        )
      );  
  }  

这有效,例如,我可以从组件中订阅该功能

    this.myService.doSomething().subscribe(
        (result) => {
            console.log(result);
        },
        (err) => {
            console.log("ERROR!!!");
        }
    );

Al已经可以使用,但我想重构以便删除

 if (data && data['success'] && data['success'] === true)
在我的地图上。这样,只有当我提前进行检查时,才会执行map函数。我的第一个想法是在管道堆栈中添加一个将从http客户端获取响应的函数,检查条件是否良好,否则抛出错误(使用throwError函数)。但是我在努力如何(至少要弄清楚要使用的Rxjs函数)。

有人可以帮我吗?

1 个答案:

答案 0 :(得分:2)

尝试使用此:

toRowMatrix()

您必须首先执行mergeMap才能进行检查,因为如果无法观察到的结果将不可用...