【发布时间】:2020-03-14 19:36:39
【问题描述】:
我需要为我的ngComponentOutlet 使用某种@Input() 装饰器。
但是 Angular 似乎没有这个功能。相反,我想在我的出口组件中传递的所有东西都应该通过Injector 提供。
如果我想在可注入类中启动我想要提供的东西,那很好。但我需要更深入地研究并在创建 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 数组中并在可注入组件Greeter 中获取NgTemplateOutletCompleteExample.suffix$ - 它会起作用。但问题是我有很多 NgTemplateOutletCompleteExample 组件,这对我来说是无效的。
【问题讨论】:
标签: angular typescript dependency-injection ng-component-outlet