1

我正在开发一个 ionic v3 应用程序:我声明了我的所有提供者,但其中一个无法在另外两个提供者中解决

我收到了这个错误:

Uncaught Error: Can't resolve all parameters for DialogueMetier:([object Object], [object Object], [object Object], [object Object],?, [object Object], [object Object]).

这是我的“未解决”提供商:

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

import { TechniqueMetier } from './technique';
import { GlobalVarsMetier } from './global-vars';
import { SynchronisationMappingMetier } from './synchronisation-mapping-metier';
import { InformationBdd } from '../bdd/information-bdd';
import { OutilMetier } from './outil-metier';
import { NotificationMetier } from './notification-metier';
import { InformationActionMetier } from './information-action-metier';
import { InformationAssocieeMetier } from './information-associee-metier';
import { InformationDestinataireMetier } from './information-destinataire-metier';
import { InformationDossierMetier } from './information-dossier-metier';
import { EvenementMetier } from './evenement-metier';
import { DialogueMetier } from './dialogue-metier';
import { TacheMetier } from './tache-metier';
import { DocumentMetier } from './document-metier';

@Injectable()
export class InformationMetier {

constructor(
    public techniqueMetier : TechniqueMetier,
    public rootScope : GlobalVarsMetier,
    public synchronisationMappingMetier : SynchronisationMappingMetier,
    public informationBdd : InformationBdd,
    public outilMetier : OutilMetier,
    public notificationMetier : NotificationMetier,
    public informationActionMetier : InformationActionMetier,
    public informationAssocieeMetier : InformationAssocieeMetier,
    public informationDestinataireMetier : InformationDestinataireMetier,
    public informationDossierMetier : InformationDossierMetier,
    public evenementMetier : EvenementMetier,
    public dialogueMetier : DialogueMetier,
    public tacheMetier : TacheMetier,
    public documentMetier : DocumentMetier 
    ) {
}

这是一个无法解决的问题:

import { Injectable } from '@angular/core';
import { InformationMetier } from './information-metier';
import { InformationAssocieeMetier } from './information-associee-metier';
import { InformationDestinataireMetier } from './information-destinataire-metier';
import { SynchronisationMappingMetier } from './synchronisation-mapping-metier';
import { DossierMetier } from './dossier-metier';
import { DialogueMessageMetier } from './dialogue-message-metier';
import { DialogueBdd } from '../bdd/dialogue-bdd';


@Injectable()
export class DialogueMetier {

    constructor(
        public synchronisationMappingMetier : SynchronisationMappingMetier,
        public informationAssocieeMetier : InformationAssocieeMetier,
        public informationDestinataireMetier : InformationDestinataireMetier,
        public dossierMetier : DossierMetier,
        public informationMetier : InformationMetier,
        public dialogueMessageMetier : DialogueMessageMetier,
        public dialogueBdd : DialogueBdd) {
    }

我试着理解出了什么问题。我将所有提供者放在 app.module.ts 中的提供者声明中。

有人知道我做错了什么吗?

4

1 回答 1

0

发生这种情况是因为循环依赖在您的情况下,InformationMetier 依赖于依赖于 InformationMetier 的 DialogueMetier。

当 Angular 的引导进程尝试设置所有服务并注入每个服务的依赖项时,它会检测到这种情况何时发生并出错,而不是陷入无限循环。

您需要重构任何一项服务,使其不需要引用另一项服务。

于 2018-08-20T15:35:16.260 回答