依赖注入(Dependency Injection, DI)早在 Java Spring 框架中就出现了,它的主要作用是解耦,通过依赖注入机制,我们可以方便的实现代码重用、独立单元测试以及代码可维护性等好处。在Angular2 SPA 应用中,依赖注入也是非常重要的一部分,称之为 Angular2的核心特性之一也不为过。
什么是依赖注入(Dependency Injection)?
依赖注入(DI),顾名思义,就是将一个对象的依赖关系注入到另一个对象中,以实现对象之间的解耦。简单来说,在实例化一个对象时,如果这个对象需要依赖于其他对象,那么我们不必自己去创建这些依赖对象,只需要将它们传入该对象中即可。
举个例子,当我们在写一个服务时,如果需要使用到一个Http对象,那么我们不必自己去创建这个Http对象,而是让Angular2框架把它注入(Injecting)到我们写的服务中。这样,我们就不用关心这个Http对象的创建和初始化,而是可以专注于服务逻辑的实现。
依赖注入的优点
依赖注入的最大优点在于解耦,不仅仅是对象之间的解耦,更是业务逻辑与对象的解耦。我们可以将一个对象的创建及维护过程交由Angular2框架,这样我们只需要专注于业务逻辑的实现,提高了代码的可维护性,同时也加速了开发流程。
其次,在使用依赖注入时,我们可以方便地配置、装配对象。例如,当我们需要集成一个第三方库时,我们可以将它抽象为一个服务,通过依赖注入机制将它注入到我们需要的服务中,这样就可以将集成过程简化为依赖注入的过程。
依赖注入还有一个非常重要的优点: 方便单元测试。在使用依赖注入时,我们可以隔离对象之间的依赖关系,单元测试时只需要传入符合要求的对象即可,降低了单元测试的难度。
Angular2中的依赖注入
在Angular2应用中,依赖注入是一个非常重要的概念,被用于创建组件、服务、指令等。无论我们是在创建组件还是服务,我们都要使用注入器(Injector)将依赖关系进行注入,Angular2框架为我们提供了一个强大的依赖注入系统。
依赖注入系统的核心有三部分组成: 注入器、提供器、注入标记。
注入器(Injector)
注入器是一个存储提供器的容器,利用它可以获取被注入的实例。在Angular2中,每个组件、服务等都有一个注入器。注入器可以通过注入标记(Injectable)获取到对应的实例。
提供器(Provider)
提供器是告诉注入器怎样创建实例的方式。它是一个具有一个或多个提供器(token)的注册类,可以通过@NgModule或@Component装饰器的providers属性提供给注入器使用。
Angular2框架为我们提供了多种提供器,包括"Class providers"、"Factory providers"、 "Value Providers"等。在这里,我们就以"Class providers"为例进行讲解。
注入标记(Injectable)
注入标记是一个特殊的装饰器,被用于标记需要进行注入的类型。当我们使用注入标记时,就可以将该类型注入到组件、服务等需要的地方。
一个简单的例子
以下代码展示了如何创建一个简单的服务并将其注入到组件中:
-- -------------------- ---- ------- ------------- ------ ----- ----------- - ------- ------ ------ - - - --- -- ----- ------ -- - --- -- ----- --------- - --- -- ----- -------- -- ----------- ------ - ------ ----------- - - ------------ --------- ------------ --------- - -------- ---------- ---- --- ----------- ---- -- ------------------------- ----- -- ---------- ------------- -- ------ ----- -------------- - ------ ------- ------------------------ ------------ - ---------- - ----------------------- - -
在该代码中,我们首先创建了一个UserService服务,该服务包括了一个返回用户列表的方法getUsers。接着,稍微向下看,我们可以看到在UsersComponent中通过注入器将UserService服务进行了注入。
最后,我们通过Angular2的ngFor指令循环输出用户列表。是不是很简单呢?当然,依赖注入并不止于此,你可以在复杂组件及服务中灵活运用它,实现解耦等目的。
总结
在Angular2 SPA应用中,依赖注入是至关重要的,学习掌握它可以提高代码的可维护性、加速开发流程,并且也能帮助我们写出更好的单元测试。
无论是在创建组件还是服务中,我们都要使用注入器将依赖关系进行注入,并通过提供器告诉注入器如何创建实例。在使用注入标记时,就可以将该类型注入到组件、服务等需要的地方。
在实际应用中,我们需要尽量将依赖注入应用到组件、服务、指令等每一个角落,以达到高内聚、低耦合的效果。
最后,希望大家能够掌握依赖注入的基本原理及应用方法,并将其应用到自己的Angular2 SPA应用中。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/64c0af1f83d39b48815051c3