全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

AngularJS的依赖注入实例分析(使用module和injector)

本文实例分析了AngularJS的依赖注入。分享给大家供大家参考,具体如下:

依赖注入(DI)的好处不再赘言,使用过spring框架的都知道。AngularJS作为前台js框架,也提供了对DI的支持,这是JavaScript/jQuery不具备的特性。angularjs中与DI相关有angular.module()、angular.injector()、 $injector、$provide。对于一个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。

// 传递参数不止一个,代表新建模块;空数组代表该模块不依赖其他模块
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 $provide service has a number of methods for registering components with the $injector. Many of these functions are also exposed on angular.Module.

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

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

var injector = angular.injector();
alert(injector.has("$provide"));//false
alert(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;
});
// 获取injector
var injector = angular.injector(["myModule"]);
// 第一种inference
injector.invoke(function(myService){alert(myService.my);});
// 第二种annotation
function explicit(serviceA) {alert(serviceA.my);};
explicit.$inject = ['myService'];
injector.invoke(explicit);
// 第三种inline
injector.invoke(['myService', function(serviceA){alert(serviceA.my);}]);

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

更多关于AngularJS相关内容感兴趣的读者可查看本站专题:《AngularJS入门与进阶教程》及《AngularJS MVC架构总结》

希望本文所述对大家AngularJS程序设计有所帮助。


# AngularJS  # 依赖注入  # module  # injector  # angular 服务的单例模式(依赖注入模式下)详解  # 深入理解Angular中的依赖注入  # Angular 4依赖注入学习教程之InjectToken的使用(八)  # Angular 4依赖注入学习教程之ValueProvider的使用(七)  # AngularJS学习第二篇 AngularJS依赖注入  # 自学实现angularjs依赖注入  # Angular.JS学习之依赖注入$injector详析  # AngularJS $injector 依赖注入详解  # 详解Angular依赖注入  # 这是  # 加载  # 多个  # 都是  # 进阶  # 不依赖  # 有一  # 也不  # 都有  # 我还  # 相关内容  # 不太  # 已有  # 也能  # 中有  # 感兴趣  # 给大家  # 不存在  # 可以看到  # 三种 


相关文章: 如何在七牛云存储上搭建网站并设置自定义域名?  湖北网站制作公司有哪些,湖北清能集团官网?  哈尔滨网站建设策划,哈尔滨电工证查询网站?  建站主机与虚拟主机有何区别?如何选择最优方案?  网站设计制作企业有哪些,抖音官网主页怎么设置?  如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  早安海报制作网站推荐大全,企业早安海报怎么每天更换?  长沙企业网站制作哪家好,长沙水业集团官方网站?  c# await 一个已经完成的Task会发生什么  打鱼网站制作软件,波克捕鱼官方号怎么注册?  建站之星好吗?新手能否轻松上手建站?  php条件判断怎么写_ifelse和switchcase的使用区别【对比】  如何快速搭建安全的FTP站点?  广州建站公司哪家好?十大优质服务商推荐  实例解析Array和String方法  C++如何将C风格字符串(char*)转换为std::string?(代码示例)  清除minerd进程的简单方法  网站微信制作软件,如何制作微信链接?  C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)  建站主机CVM配置优化、SEO策略与性能提升指南  视频网站app制作软件,有什么好的视频聊天网站或者软件?  已有域名如何免费搭建网站?  如何通过西部数码建站助手快速创建专业网站?  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  重庆网站制作公司哪家好,重庆中考招生办官方网站?  网站制作话术技巧,网站推广做的好怎么话术?  如何快速登录WAP自助建站平台?  如何在腾讯云服务器上快速搭建个人网站?  实现虚拟支付需哪些建站技术支撑?  高防服务器如何保障网站安全无虞?  建站之星下载版如何获取与安装?  网站制作壁纸教程视频,电脑壁纸网站?  如何快速生成橙子建站落地页链接?  建站之星3.0如何解决常见操作问题?  建站OpenVZ教程与优化策略:配置指南与性能提升  企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?  如何在建站宝盒中设置产品搜索功能?  南平网站制作公司,2025年南平市事业单位报名时间?  建站之星展会模板:智能建站与自助搭建高效解决方案  制作证书网站有哪些,全国城建培训中心证书查询官网?  大学网站设计制作软件有哪些,如何将网站制作成自己app?  如何在宝塔面板创建新站点?  C++如何编写函数模板?(泛型编程入门)  网页设计网站制作软件,microsoft office哪个可以创建网页?  如何安全更换建站之星模板并保留数据?  ppt制作免费网站有哪些,ppt模板免费下载网站?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  实惠建站价格推荐:2025年高性价比自助建站套餐解析  大型企业网站制作流程,做网站需要注册公司吗? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。