angular - 依赖注入(inject)相同类型的祖先组件?

标签 angular typescript

Angular 的依赖注入(inject)允许你注入(inject)任何祖先组件,像这样:

@Component({ ... })
export class MyComponent {
    constructor(_parent: AppComponent) {}
}

但在我的例子中,我想注入(inject)一个祖先组件,它是同一组件类的另一个实例,如下所示:

@Component({ ... })
export class MyComponent {
    constructor(_parent: MyComponent) {}
                         ^^^^^^^^^^^
}

这会产生循环依赖错误,大概是因为它引用了同一个实例。

在我的例子中,我无法通过 @Input() 注入(inject)其他组件,因为它不会成为直接父组件,而是完全动态/未知的祖父/曾祖父组件。

最佳答案

使用@SkipSelf()装饰器。

export class HelloComponent  {
  constructor(@SkipSelf() @Optional() private parent: HelloComponent) {
  }
}

Demo

关于angular - 依赖注入(inject)相同类型的祖先组件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55129518/

相关文章:

javascript - 为什么 var 允许重复声明,而 const 和 let 却不允许重复声明?

IE11 中的 Angular 4 错误

angular - IntelliJ IDEA 显示 matHeaderRowDef 错误

javascript - parcel serve 为 SourceMap 请求和不存在的 url 返回 index.html

angularjs - Angular:req.handle.writev 不是函数,运行 Angular 旧应用程序时出错

javascript - 将 GeoFire 与 Firebase 9.17.1 一起使用时出现类型错误 : "t.split is not a function"

javascript - KnockoutJS 使用 TypeScript 填充 observableArray

angular - Datalayer.push 在 Angular 6 中使用 Typescript

javascript - TS4060 : Return type of exported function has or is using private name 'class'

Angular 2 - 什么是可声明项?