如何从Observables值构造数据,并在HTTP调用后返回Observable <response>?

时间:2016-11-28 15:36:58

标签: http angular typescript observable

在构建包含从Observable解析的值的数据对象时,我无法确定如何返回Observable<Response>

我已尝试使用forkJoin(),首先解析值,然后subscribe,然后返回this.http.post()...来电。但是,这使得无法订阅函数本身fetchData().subscribe( ... )。我显然遗漏了一些东西。

那么,我如何构建一个包含已解析的Observable值的数据对象,然后返回Observable<Response>个对象?

// Simplified example 

fetchData() { 

  // Construct the data
  var data = {
      v1 : this.getValueFromObservable1(),
      v2 : this.getValueFromObservable2()
  };

  // Make the call, return the Observable<Response> object
  return this.http
      .post( 'api/authorization', JSON.stringify(data) );
}

1 个答案:

答案 0 :(得分:0)

这应该做你想要的:

fetchData() {
    return this.getValueFromObservable1()
    .mergeMap(v1 => 
          this.getValueFromObservable2()
          .map(v2 => { v1: v1, v2: v2})
    );
}