相关疑难解决方法(0)

Angular 2 - 从promise内部返回HTTP

在我的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())

      });


  }
Run Code Online (Sandbox Code Playgroud)

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

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

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

对此进行评估的正确方法是什么?在这个设置中,是否有更有效的方法可以从本地存储中获取令牌?注意:我正在使用Ionic 2,它有自己的功能来检查返回承诺的本地存储.

任何建议都会很棒.

谢谢.

javascript ionic2 angular

1
推荐指数
1
解决办法
1084
查看次数

标签 统计

angular ×1

ionic2 ×1

javascript ×1