10

这个问题已经在这里问过了。但是,由于提问者的应用程序上下文在问题中涉及太多,我无法理解基础知识。例如,有一个queryArr参数。它有什么作用?

无论如何,我需要一点关于如何以最简单的方式进行同步 http 调用的指导。我想出的解决方案是必须以“嵌套”顺序订阅 observables。例如,有 observablesoxoy. 被调用的请求oy的数据取决于数据来自ox

xData: string = "";
yData: string = "";  

ox.subscribe(
    data => {xData = data;},
    error => console.log(error),
    () => {
        oy.subscribe(
            data => {yData = xData*data;},
            error => console.log(error),
            () => console.log("aaa")
        );
    }
);

上次我记得(我不怎么做javascript,而且是一个小新手),在我订阅的范围内oyxDataoryData不能再看到了。如果我错了,请纠正我并指出正确的方向。

有没有“好的”解决方案或更好的方法来做这种事情?

4

1 回答 1

10

我认为您可以查看flatMap操作员来执行 HTTP 请求,等待其响应并执行另一个。

这是一个示例:

executeHttp(url) {
  return this.http.get(url).map(res => res.json());
}

executeRequests() {
  this.executeHttp('http://...').flatMap(result => {
    // result is the result of the first request
    return this.executeHttp('http://...');
  }).subscribe(result => {
    // result is the result of the second request
  });
}

如果您想访问该subscribe方法中的两个结果,您可以利用Observable.forkJoinand Observable.of

executeRequests() {
  this.executeHttp('http://...').flatMap(result => {
    // result is the result of the first request
    return Observable.forkJoin(
      Observable.of(result),
      this.executeHttp('http://...')
    ).subscribe(results => {
    // results is an array of the results of all requests
    let result1 = results[0];
    let result2 = results[1];
  });
}
于 2016-08-10T13:59:16.780 回答