Мне нужно использовать какой-нибудь декоратор @Input()
для моего ngComponentOutlet
.
Но кажется, что Angular не имеет этой функции. Вместо этого все, что я хочу передать внутри своих компонентов выхода, должно быть предоставлено через Injector
.
И это нормально, если я хочу инициировать то, что я хочу предоставить внутри инъекционного класса. Но мне нужно погрузиться глубже и предоставить какую-то наблюдаемую переменную (например, тип Observeble<number>
) на этапе создания инжектора. Но я не могу получить наблюдаемую переменную внутри выходного компонента. Получение следующей ошибки: NullInjectorError: No provider for [object Object]!
.
Вот пример кода, я получил этот шаблон из документов angular (angular.io/api/common/NgComponentOutlet) и немного изменен:
@Injectable()
export class Greeter {
suffix$: Observable<number> = null;
constructor(private _suffix$: Observable<number>) {
this.suffix$ = this._suffix$;
}
}
@Component({
selector: 'complete-component',
template: `Complete: {{ greeter.suffix$ | async }}`
})
export class CompleteComponent {
constructor(public greeter: Greeter) {
this.greeter.suffix$.subscribe(data => console.log('data', data));
// not working
}
}
@Component({
selector: 'ng-component-outlet-complete-example',
template: `
<ng-container *ngComponentOutlet="CompleteComponent;
injector: myInjector;"
})
export class NgTemplateOutletCompleteExample {
CompleteComponent = CompleteComponent;
myInjector: Injector;
suffix$: Observable<number> = of(3);
constructor(injector: Injector) {
this.myInjector =
Injector.create({providers: [{provide: Greeter, deps: [this.suffix$]}], parent: injector});
}
}
Итак, как я могу получить и подписаться на эту переменную $suffix
внутри компонента выхода.
P.S. Если я передам NgTemplateOutletCompleteExample
в массив deps
и получу NgTemplateOutletCompleteExample.suffix$
внутри инжектируемого компонента Greeter
- это сработает. Но дело в том, что у меня много компонентов NgTemplateOutletCompleteExample
, и эта вещь не подходит для моего случая.