angular - http provider Observable.toPromise() 在 promise 链中没有按预期工作

标签 angular angular2-services

如果我使用 ng2 http 提供程序 Observable.toPromise() 支持调用启用 promise 的方法,它会按预期工作,但是当我将它用作 promise 链的一部分时,它会在 then 处理程序处理并返回结果之前解析返回的 promise .

关于让 Observable.toPromise() 在 promise 链中工作的任何已知问题或我可能测试以使其成为 promise 链兼容结果的替代方式?在 http 请求(promise 链中的最后一项)完成其异步请求并返回结果之前,我被这个 resolving promise 阻止了。

例如

this.myService.getSomethingInvolvingingMultiplePromiseCalls().then(result => {
    let valueFromSomethingInvolvingMultiplePromiseCalls = result;
}, err => { 
    console.error('landed in app.component outer promise rejected handler, see output window for details')
})

public getSomethingInvolvingingMultiplePromiseCalls(): Promise<string> {
    return this.getSomethingInvolvingPromiseCall().then(resultPromise1 => {
        let resultPromise1propertyFoo = resultPromise1.propertyFoo;
            return this.getSomethingInvolvingNg2HttpProviderToPromiseCall(resultPromise1propertyFoo);
        }
        .then(resultPromise2 => {
            let resultPromise2propertyBar = resultPromise2.propertyBar;
            return resultPromise2propertyBar;
        }   
    }

getSomethingInvolvingNg2HttpProviderToPromiseCall(arg1: string): Promise<string> {
   let body = 'some body content leveraging arg1';
   let headers = new Headers({ 'Authorization': 'Bearer ' + accessToken, 'Content-Type': 'application/x-www-form-urlencoded' });
   let options = new RequestOptions({ headers: headers });

   return this.http.post(resourceBaseAddress + '/someRestApi', body, options).toPromise().then(response => {
        let responseJson = response.json();
        return responseJson['someJsonProperty'];
      });
    }
}

提前感谢您的任何见解或建议。

最佳答案

我找到了解决这个问题的方法。

它涉及创建和返回一个 typescript 延迟 promise ,只有当我进入 then 处理程序以使用 angular2 http 提供程序 toPromise() 调用方法时,我才控制解析。

我不必处理其他 promise 链场景,但无论出于何种原因,在这种情况下都允许停放方法调用者,直到链中的 http 提供程序 toPromise() 调用完成。

public getSomethingInvolvingingMultiplePromiseCalls(): Promise<string> {
    let resolveFn, rejectFn;
    let promise = new Promise((resolve, reject) => { resolveFn = resolve; rejectFn = reject; });

    this.getSomethingInvolvingPromiseCall().then(resultPromise1 => {
        this.getSomethingInvolvingNg2HttpProviderToPromiseCall(resultPromise1).then(resultPromise2 => resolveFn(resultPromise2));
    }

    return promise;  // return the promise for outside callers to wait on
}

关于angular - http provider Observable.toPromise() 在 promise 链中没有按预期工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35529245/

相关文章:

angular - 在两个页面/选项卡之间共享数据

angular - 强制多个组件使用同一个服务实例

Angular 2路由器导航功能不起作用

javascript - 在JS文件中使用组件的成员变量

angular - 如何将参数传递给canActivate的构造函数?

http - 我在哪里可以进行模拟 http 调用来学习 Angular2 前端 http 调用

angular - 来自订阅的异步 get 请求的响应将在另一个 get 请求中使用

javascript - 如何限制输入文本框只能以 Angular2 形式输入数字?

javascript - Angular 4 - 新的 MouseEvent 导致 IE11 错误

angular - 服务命令需要在 Angular 项目中运行 - Azure 应用服务(.NetCore 和 Angular 应用程序)