0

我有一个组件应该根据添加到元素的指令来改变其行为。此自定义逻辑在指令中定义,因此在添加新范围/功能时无需修改组件。

MyComponent
MyDirectiveBase
MyDirective1 extends MyDirectiveBase
MyDirective2 extends MyDirectiveBase

在组件构造函数中,我想注入应用于元素的指令。当我知道将使用的确切类时,我可以毫无问题地做到这一点,但我想要的是从 MyDirectiveBase 扩展的任何指令。

如何告诉 DI 框架允许 MyDirectiveBase 的所有子类?

我曾尝试使用注入令牌(multi=true),但这只是给了我一个类/函数数组,而不是元素实例。此外,如果未指定属性,则不应注入任何指令。

示例仓库: https ://github.com/ulvesked/angular-dependency-inject-directive-subclass-to-component

StackBlitz:https ://stackblitz.com/edit/angular-ivy-bihzjv?devtoolsheight=33&file=src/app/app.component.html

4

1 回答 1

1

这是一个示例。

https://stackblitz.com/edit/angular-ivy-tnb5up

基本思想是使每个指令为基本类MyGreetingDirective提供实现类。所以 HelloComopnent 可以根据你的属性从 Angular DI 中获取不同的指令实例。

于 2021-01-14T07:29:49.180 回答