这期内容当中小编将会给大家带来有关怎么在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项目中对依赖进行注入了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注行业资讯频道。