【问题标题】:Angular 2 - Return HTTP from inside a promiseAngular 2 - 从承诺中返回 HTTP
【发布时间】:2017-08-04 21:59:28
【问题描述】:

在我的 api 服务中的每个 http 调用之前,我想检查我的本地存储是否有访问令牌,然后在我拥有它后进行调用。看起来是这样的

read(endpoint,params?) {

    var url: string = this.authService.apiUrl + endpoint, 
        headers: Headers = new Headers(),
        queryString: URLSearchParams = new URLSearchParams();

    this.sessionService.getToken()
      .then((value) => {

        queryString.set('access_token', value);

        headers.append('Content-Type', 'application/json; charset=utf-8');

        return this.http.get(url,{
          headers: headers, 
          search: queryString
        })
        .map(res => res.json())

      });


  }

在我的组件中,我会有类似的东西

  getData() {
    this.apiService.read('some endpoint')
      .subscribe(
        res => console.log(res),
        error => this.logError(error)
      )
  }

这一直有效,直到我在检查本地存储后将 http 调用放入 .then 中。所以我认为它现在嵌套不正确。

解决这个问题的正确方法是什么?在此设置中,是否有更有效的方式从本地存储中获取我的令牌?注意:我使用的是 Ionic 2,它有自己的功能来检查返回承诺的本地存储。

任何建议都会很棒。

谢谢。

【问题讨论】:

    标签: javascript angular ionic2


    【解决方案1】:

    您必须将 http observable 转换为 promise 或将 promise 转换为 observable。

    可观察到的承诺:

    read(endpoint,params?) {
    
        var url: string = this.authService.apiUrl + endpoint, 
            headers: Headers = new Headers(),
            queryString: URLSearchParams = new URLSearchParams();
    
        return this.sessionService.getToken() //return the outer promise
          .then((value) => {
    
            queryString.set('access_token', value);
    
            headers.append('Content-Type', 'application/json; charset=utf-8');
    
            return this.http.get(url,{
              headers: headers, 
              search: queryString
            })
            .map(res => res.json()).toPromise() //use Observable.toPromise
    
          });
    
    
      }
    

    调用使用

    this.apiService.read('some endpoint').then((data)=>{}).catch(err=>{})
    

    对 Observable 的承诺:

    read(endpoint,params?) {
    
        var url: string = this.authService.apiUrl + endpoint, 
            headers: Headers = new Headers(),
            queryString: URLSearchParams = new URLSearchParams();
    
        return Observable.fromPromise(this.sessionService.getToken())//convert to Promise and return chain.
          .switchMap((value) => {//use Observable.switchMap to move to second observable
    
            queryString.set('access_token', value);
    
            headers.append('Content-Type', 'application/json; charset=utf-8');
    
            return this.http.get(url,{
              headers: headers, 
              search: queryString
            })
            .map(res => res.json())
    
          });
    
    
      }
    

    RXJS 5.5 开始:

    对 Observable 的承诺:

    read(endpoint,params?) {
    
        var url: string = this.authService.apiUrl + endpoint, 
            headers: Headers = new Headers(),
            queryString: URLSearchParams = new URLSearchParams();
    
        return fromPromise(this.sessionService.getToken())//import {fromPromise } from "rxjs/observables/fromPromise";
         .pipe(
          switchMap((value) => {//import {switchMap} from 'rxjs/operators/switchMap';
    
            queryString.set('access_token', value);
    
            headers.append('Content-Type', 'application/json; charset=utf-8');
    
            return this.http.get(url,{
              headers: headers, 
              search: queryString
            })
          });
         );
    
      }
    

    【讨论】:

    • 这对我帮助很大。非常感谢+1 :)
    猜你喜欢
    • 2017-02-21
    • 2015-11-04
    • 2016-10-25
    • 1970-01-01
    • 2017-06-08
    • 2017-02-22
    • 1970-01-01
    • 2017-02-08
    • 2015-05-18
    相关资源
    最近更新 更多