gpt4 book ai didi

angular - 为什么 Angular CLI 不会自动在提供者数组中添加服务?

转载 作者:行者123 更新时间:2023-12-01 15:32:06 25 4
gpt4 key购买 nike

就像我们创建 Component 时一样, Pipeangular-cli命令,CLI 会自动将它们添加到特定模块的声明数组中,为什么在服务的情况下不会发生这种情况。

最佳答案

在 Angular 5 之前,您应该向 providers 添加服务Angular 模块的数组,将其注册到 Angular 模块的注入(inject)器上。
从 Angular 6 开始,服务变成了可摇树的。

What is tree-shaking?

Well, in simple terms, it means that if you don't have an import statement for a particular service, then it won't be added as a part of your bundle. This will lead to a relatively smaller bundle size.

Why was Angular Services not tree-shakable before Angular 6?

Before Angular 6, you were expected to add a service to the providers array of an Angular Module so register them onto the injector of a service. And in order to do that, you'd have to add an import statement at the top of the file to actually refer to the service. And that would make it non-tree-shakable.

But this changed in Angular 6 after the introduction of the providedIn field in the @Injectable decorator's meta-data. If that's set to a value('root' for instance), then the service would be registered for dependency injection(to the root injector in this case).

And since it would be registered on the injector for dependency injection, we won't have to explicitly add it to the providers array of an Angular Module as that in-turn does the exact same thing. And not being required to add it to the declarations array means, not being required to add an import statement for it at the top of the file.

Which in turn would make the service tree-shakable if not in use.


因此,为了回答您的问题,如果您通过 Angular CLI 在版本 6.x.x 或更高版本上生成此服务,那么该服务很可能是使用 providedIn: 'root' 生成的。添加到 @Injectable装饰师。所以它没有被添加到 providers Angular 模块的数组。

关于angular - 为什么 Angular CLI 不会自动在提供者数组中添加服务?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52131633/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com