博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Injector
阅读量:6447 次
发布时间:2019-06-23

本文共 3716 字,大约阅读时间需要 12 分钟。

依赖注入(DI)的好处不再赘言,使用过spring框架的都知道。angularjs作为前台js框架,也提供了对DI的支持,这是javascript/jquery不具备的特性。angularjs中与DI相关有angular.module()、angular.injector()、 、。对于一个DI容器来说,必须具备3个要素:服务的注册、依赖关系的声明、对象的获取。比如spring中,服务的注册是通过xml配置文件的<bean>标签或是注解@Repository、@Service、@Controller、@Component实现的;对象的获取可以ApplicationContext.getBean()实现;依赖关系的声明,即可以在xml文件中配置,也可以使用@Resource等注解在java代码中声明。在angular中,module和$provide相当于是服务的注册;injector用来获取对象(angular会自动完成依赖的注入);依赖关系的声明在angular中有3种方式。下面从这3个方面,介绍下angular的DI。

1、angular.module()创建、获取、注册angular中的模块

  The angular.module() is a global place for creating, registering and retrieving Angular modules.When passed two or more arguments, a new module is created. If passed only one argument, an existing module (the name passed as the first argument to module) is retrieved。(angular.module()是一个用于创建、注册和检索模块的全局位置。当传递两个或多个参数时,会创建一个新的模块。如果只传递一个参数,则检索现有的模块(作为第一个参数传递给模块的名称)。)

// 传递参数不止一个,代表新建模块;空数组代表该模块不依赖其他模块var createModule = angular.module("myModule", []);// 只有一个参数(模块名),代表获取模块// 如果模块不存在,angular框架会抛异常var getModule = angular.module("myModule");// true,都是同一个模块alert(createModule == getModule);

  该函数既可以创建新的模块,也可以获取已有模块,是创建还是获取,通过参数的个数来区分。

  angular.module(name, [requires], [configFn]);

    name:字符串类型,代表模块的名称;

    requires:字符串的数组,代表该模块依赖的其他模块列表,如果不依赖其他模块,用空数组即可;

    configFn:用来对该模块进行一些配置。

  现在我们知道如何创建、获取模块了,那么模块究竟是什么呢?官方的Developer Guide上只有一句话:You can think of a module as a container for the different parts of your app – controllers, services, filters, directives, etc.(你可以把模块看作是应用程序的不同部分的容器——控制器、服务、过滤器、指令)

2、$provide和模块的关系

  The  service has a number of methods for registering components with the . Many of these functions are also exposed on .

  之前提到过:module和provide是用来注册服务到injector中的。查看官方的API,可以看到$provide提供了provide()、constant()、value()、factory()、service()来创建各种不同性质的服务;angular.Module中也提供了这5个服务注册方法。其实2者功能是完全一样的,就是用来向DI容器注册服务到injector中。

  官方API下的auto有 和 ,Implicit module which gets automatically added to each $injector.按照字面意思是说,每一个injector都有这2个隐含的服务。但1.2.25版本中,感觉没有办法获取injector中的。不知道这是为什么?一般来说也不需要显示使用这个服务,直接使用module中提供的API即可。

var injector = angular.injector();alert(injector.has("$provide"));//falsealert(injector.has("$injector"));//true

3、angular.injector()

  使用angular.injector();也能获取到注入器,但是没有和模块绑定。这种做法是没有意义的,相当于是你创建了一个空的DI容器,里面都没有服务别人怎么用呢。正确的做法是,在创建注入器的时候,指定需要加载的模块。

// 创建myModule模块、注册服务var myModule = angular.module('myModule', []);myModule.service('myService', function() {            this.my = 0;});// 创建herModule模块、注册服务var herModule = angular.module('herModule', []);herModule.service('herService', function() {            this.her = 1;});// 加载了2个模块中的服务var injector = angular.injector(["myModule","herModule"]);alert(injector.get("myService").my);alert(injector.get("herService").her);

  如果加载了多个模块,那么通过返回的injector可以获取到多个模块下的服务。这个例子中如果只加载了myMoudle,那么得到的injector就不能访问herMoudle下的服务。这里特别需要注意下:angular.injector()可以调用多次,每次都返回新建的injector对象

var injector1 = angular.injector(["myModule","herModule"]);var injector2 = angular.injector(["myModule","herModule"]);alert(injector1 == injector2);//false

4、angular中三种声明依赖的方式

  angular提供了3种获取依赖的方式:inference、annotation、inline方式。

// 创建myModule模块、注册服务var myModule = angular.module('myModule', []);myModule.service('myService', function() {            this.my = 0;});// 获取injectorvar injector = angular.injector(["myModule"]);// 第一种inferenceinjector.invoke(function(myService){alert(myService.my);});// 第二种annotationfunction explicit(serviceA) {alert(serviceA.my);};explicit.$inject = ['myService'];injector.invoke(explicit);// 第三种inlineinjector.invoke(['myService', function(serviceA){alert(serviceA.my);}]);

  其中annotation和inline方式,对于函数参数名称没有要求,是推荐的做法;inference方式强制要求参数名称和服务名称一致,如果JS代码经过压缩或者混淆,那么功能会出问题,不建议使用这种方式。

转载于:https://www.cnblogs.com/sclerx/p/10624661.html

你可能感兴趣的文章
Mozilla 开源稍后阅读应用 Pocket 代码
查看>>
git 基本使用
查看>>
使用docker的mysql镜像
查看>>
学习整套基于Spring+SpringMVC+Mybatis分布式敏捷开发系统架构
查看>>
ActiveMQ学习-Network connectors
查看>>
SylixOS高精度时钟分析
查看>>
PHPCMS访问首页想到的问题
查看>>
简要理解锁、同步器之间的关系
查看>>
Webpack自动化构建实践指南
查看>>
建立虚拟wifi热点共享上网
查看>>
学会如何使用移动用户反馈系统,让你玩转APP
查看>>
PHP完全自学手册(文档教程)
查看>>
linux环境通过ssh连接控制台显示中文乱码问题
查看>>
列表增删改查
查看>>
JAVA语言基础-面向对象(代码块)
查看>>
前端加密JS库--CryptoJS 使用指南
查看>>
闪屏页设置
查看>>
12.10 Nginx访问日志 12.11 Nginx日志切割 12.12 静态文件不记录日志和过期时间
查看>>
hibernate多表联合查询接收返回结果集
查看>>
一个程序猿如何自学双截棍,避免各种编程职业病的发生?
查看>>