依赖注入 – 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,那么您需要它.

相关文章

迭代器模式(Iterator)迭代器模式(Iterator)[Cursor]意图...
高性能IO模型浅析服务器端编程经常需要构造高性能的IO模型,...
策略模式(Strategy)策略模式(Strategy)[Policy]意图:定...
访问者模式(Visitor)访问者模式(Visitor)意图:表示一个...
命令模式(Command)命令模式(Command)[Action/Transactio...
生成器模式(Builder)生成器模式(Builder)意图:将一个对...