依赖注入 – Angular 2 @Injectable() – 它是如何工作的

前端之家收集整理的这篇文章主要介绍了依赖注入 – Angular 2 @Injectable() – 它是如何工作的前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我试图理解在角度2中添加@Injectable()装饰的必要性.

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

Why don’t we add @Injectable() to the HeroesComponent? We can add it if we really want to. It isn’t necessary because the HeroesComponent is already decorated with @Component. TypeScript generates Metadata for any class with a decorator and any decorator will do.

所以基本上你只需要添加@Injectable()如果没有其他的装饰是可用的,如果有,因为可用的任何类型的装饰,打字稿编译器会自动生成基于变量您在构造如通过依赖信息:构造函数(私人记录器:记录器)

这是正确的吗?
谢谢

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

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

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

猜你在找的设计模式相关文章