当前位置:  开发笔记 > 编程语言 > 正文

Angular 2 @Injectable() - 它是如何工作的

如何解决《Angular2@Injectable()-它是如何工作的》经验,为你挑选了1个好方法。

我试图理解@Injectable()在角度2 中添加服务中装饰的必要性.

从文档:https://angular.io/docs/ts/latest/guide/dependency-injection.html

为什么我们不将@Injectable()添加到HeroesComponent?如果我们真的想要,我们可以添加它.没有必要,因为HeroesComponent已经用@Component修饰.TypeScript使用装饰器为任何类生成元数据,任何装饰器都可以.

所以基本上你只需要添加,@Injectable()如果没有其他装饰可用,因为如果有任何类型的装饰可用,typescript编译器将根据你在构造函数中传递的变量自动生成依赖信息,例如:constructor(private logger: Logger)

这是正确的吗?谢谢



1> Per Hornshøj..:

我觉得这个名字有点奇怪,我真的不明白为什么他们会告诉你把它添加到最佳实践中.如果将它添加到每个类是最佳实践,我不明白它为什么需要它.如果构造函数需要注入的东西,那么让框架检查每个类会更容易.这可以通过typescript上的命令行属性来解决,以始终生成(模拟)元数据.

总是添加它的建议,我想类似于编译器总是添加元数据(据我所知,这是不可能的).你也可以(保持警惕)只将(并且总是)添加到需要注入东西的类中 - 即使他们有另一个装饰器.那可能是最明确的解决方案 - 但是嘿 - 邋 - 可能既是坏事又是好事.在这种情况下,你将成为法官.

TL; DR 如果您没有其他装饰器 ,并且如果您的构造函数需要注入服务/ etc,那么您需要它.

推荐阅读
黄晓敏3023
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有