【问题标题】:Accessing service from exported function in a module declaration in Angular 2+从Angular 2+中模块声明中的导出函数访问服务
【发布时间】:2017-09-05 12:06:40
【问题描述】:

我有以下模块声明:

import { ConnectionService } from './services/connection.service';
import { NgModule } from '@angular/core';
import { Http, RequestOptions } from '@angular/http';
import { AuthHttp, AuthConfig } from 'angular2-jwt';

export function authHttpServiceFactory(http: Http, options: RequestOptions) {
  return new AuthHttp(new AuthConfig({
    tokenName: 'token',
    tokenGetter: (() => sessionStorage.getItem('token'))
  }), http, options);
}

@NgModule({
  providers: [
    {
      provide: AuthHttp,
      useFactory: authHttpServiceFactory,
      deps: [Http, RequestOptions]
    }
  ],
})

export class AuthModule { }

和服务:

import { Injectable } from '@angular/core';

@Injectable()
export class ConnectionService {
    id;

    getToken() {
        return JSON.parse(sessionStorage.getItem('token'))[this.id];
    }
}

我需要在模块导出函数的 tokenGetter 中使用服务方法“getToken”,但我无法使其工作并且 Google 没有回答我的问题(或者我无法正确查看) .

【问题讨论】:

    标签: angular typescript service injectable


    【解决方案1】:

    你好,你可以这样试试

    export function authHttpServiceFactory(http: Http, options: RequestOptions) {
      return new AuthHttp(new AuthConfig({
           tokenName: 'token',
           tokenGetter: (() => new ConnectionService().getToken())
           }), http, options);
     }
    

    【讨论】:

    • 谢谢,但它对我不起作用。最后我反其道而行之,直接在服务内部定义了“AuthHttp”对象。
    • 我无法尝试。在实际项目中,我在服务中有一个构造函数来访问 Http 和其他东西,所以它没有让我。但无论如何,我认为将对象添加到服务而不是相反是一种更好的方法,至少在我的情况下是这样。
    猜你喜欢
    • 2017-06-02
    • 1970-01-01
    • 1970-01-01
    • 2018-10-13
    • 2017-02-09
    • 2017-04-16
    • 2019-05-29
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多