怎么在Angular4项目中对依赖进行注入

  介绍

这期内容当中小编将会给大家带来有关怎么在Angular4项目中对依赖进行注入,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

<强>一、注入器

角中的注入器只有一种实现方法就是在构造函数中声明。

例如在一个组件中

构造函数(productService: productService) {}

通俗的讲这段代码的意思就是说,这个组件创建了一个productService,而这个productService是依赖productService的,这里的productService只是一个道理,至于productService是什么,是怎么实现的,全都是由提供器说明的。

<强>二,提供器

通常提供器定义在应用级,及app.module。ts中,供所有组件或服务使用,当然也可以定义在某一个组件中,只供这一个组件使用。

我们以定义在应用级为例:

@NgModule ({   提供才能(ProductService):   })

这段代码其实这一个简写,全写为:

@NgModule ({   提供:[{才能   ,,,提供:,ProductService,   ,,,useClass: ProductService   })才能   })

这段代码中的提供声明的就是我们刚刚在注入器中提过的令牌,就是说这两个令牌是一一对应的,角会到提供器中找到和注入器相同的令牌。

代码中的useClass是实例化ProductService类,及我们帮助我们新了一个类出来。除了useClass外,比较常用的还用useFactory,使用工厂模式实例化一个类。

这时候我们在组件中就可以直接使用ProductService类中的方法了。

当令牌和想要实例化的类名字相同时,我们就可以使用上面那种简写的方法。

说了这么多,那到底怎么才能体现出可复用性呢?

如果现在我们的产品组件用到了另一个地方需要使用另一个服务,我们命名为AnotherProductService。有了依赖注入我们就不必要更改组件,而是更改app.module。ts中的提供器:

@NgModule ({   ,,提供:ProductService,   useClass才能:AnotherProductService   })

从这段代码可以看的出,令牌并没有改变,可是这是实例化的类变为了AnotherProductService。

总结来说,当组件在构造函数中说明自己想要依赖一个类时,角首先会在这个组件自身找有没有提供器,如果没有就去这个组件的父组件中找,如果也没有找到就去应用级(app.module。ts)中找,找到后,就会按照提供器可说明的为组件注入它想要的。

上述就是小编为大家分享的怎么在Angular4项目中对依赖进行注入了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注行业资讯频道。

怎么在Angular4项目中对依赖进行注入