Angular 2 angular2.dev.js:23925 EXCEPTION:错误:未捕获(承诺):没有提供者

时间:2016-05-21 13:49:59

标签: angular angular2-providers

我正在尝试将具有配置文件(datService.configuration)的Angular Service(DataService)加载到Component(Home)中。在我的Home组件中,如果我没有将DataServiceConfiguration添加到提供者列表,我会收到以下错误:

“未捕获(承诺):没有DataServiceConfiguration提供商!(主页 - > DataService - > DataServiceConfiguration)”

dataService.ts:

import { Injectable } from 'angular2/core';
import { Http, Response, Headers, HTTP_PROVIDERS } from 'angular2/http';
import 'rxjs/add/operator/map'
import { Observable } from 'rxjs/Observable';
import { DataServiceConfiguration } from './dataService.configuration';

@Injectable()
export class DataService {

    private actionUrl: string;
    private headers: Headers;

    constructor(private _http: Http, private configuration: DataServiceConfiguration) {

        ...
    }

dataService.configuration.ts:

import { Injectable } from 'angular2/core';

@Injectable()
export class DataServiceConfiguration {
    public Server: string = "http://localhost/";
    public ApiPath: string = "api/v1/";
    public ApiUrl = this.Server + this.ApiPath;

    constructor() {
    }
}

Home.ts

import { DataService } from '../services/dataService';
import { DataServiceConfiguration } from '../services/dataService.configuration';

import {
    Headers,
    Http,
    HTTP_BINDINGS, 
    Request,
    RequestOptions,
    RequestOptionsArgs,
    HTTP_PROVIDERS
} from 'angular2/http';

@ng.Component({
  selector: 'home',
  templateUrl: './ng-app/components/public/home/home.html',
  directives: [AlbumTile, ProdutoTile, Promocao, SuperOfertas, Banner, Categorias, DestaquesDaHome],
  providers: [DataServiceConfiguration, DataService]
})
export class Home implements ng.OnInit {
    public lista: models.Lista;
    public pagina: number = 1;
    paginas: number = 1;

    constructor(private http: Http, private _dataService: DataService) {

    }
}

我不明白为什么我需要将DataServiceConfiguration添加到我的Home组件,因为我的DataService已经加载它。有没有办法只将DataService添加到我的组件?

1 个答案:

答案 0 :(得分:2)

有点奇怪,但只有组件可以在Angular中配置依赖注入(well,和bootstrap(),但这与root组件基本相同)。即,只有组件可以指定提供者。

组件树中的每个组件都将获得一个关联的"注入器"如果组件指定了providers数组。我们可以把它想象成一个注入器树,它(通常很多)比组件树更稀疏。当需要解析依赖关系(通过组件或服务)时,将查询此注入器树。能够满足依赖性的第一个注入器就是这样做的。进样器树向上走,朝向根部件/进样器。

因此,为了使您的服务注入配置对象依赖项,首先必须使用注入器注册该配置对象。即,在组件的providers数组中。此注册必须发生在您要使用/注入服务的组件上或其上方。

您的服务应该能够注入已注册的配置对象,因为它会在注入器树中找到它。

另见Angular 2 - Including a provider in a service