本文实例分析了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依赖注入
# 这是
# 加载
# 多个
# 都是
# 进阶
# 不依赖
# 有一
# 也不
# 都有
# 我还
# 相关内容
# 不太
# 已有
# 也能
# 中有
# 感兴趣
# 给大家
# 不存在
# 可以看到
# 三种
相关文章:
如何用PHP快速搭建CMS系统?
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
,网站推广常用方法?
如何零基础在云服务器搭建WordPress站点?
较简单的网站制作软件有哪些,手机版网页制作用什么软件?
如何快速生成可下载的建站源码工具?
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
如何在宝塔面板中创建新站点?
兔展官网 在线制作,怎样制作微信请帖?
建站之星代理商如何保障技术支持与售后服务?
枣阳网站制作,阳新火车站打的到仙岛湖多少钱?
安徽网站建设与外贸建站服务专业定制方案
建站为何优先选择香港服务器?
建站之星后台管理:高效配置与模板优化提升用户体验
建站主机是什么?如何选择适合的建站主机?
,石家庄四十八中学官网?
深圳企业网站制作设计,在深圳如何网上全流程注册公司?
Swift中循环语句中的转移语句 break 和 continue
已有域名和空间如何搭建网站?
Thinkphp 中 distinct 的用法解析
制作网站的软件免费下载,免费制作app哪个平台好?
唐山网站制作公司有哪些,唐山找工作哪个网站最靠谱?
如何选择高效便捷的WAP商城建站系统?
如何在阿里云高效完成企业建站全流程?
青岛网站建设如何选择本地服务器?
如何高效配置IIS服务器搭建网站?
清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?
个人网站制作流程图片大全,个人网站如何注销?
存储型VPS适合搭建中小型网站吗?
高性价比服务器租赁——企业级配置与24小时运维服务
如何自定义建站之星网站的导航菜单样式?
品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
网站代码制作软件有哪些,如何生成自己网站的代码?
免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?
常州企业网站制作公司,全国继续教育网怎么登录?
如何选择香港主机高效搭建外贸独立站?
武汉外贸网站制作公司,现在武汉外贸前景怎么样啊?
视频网站制作教程,怎么样制作优酷网的小视频?
沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?
平台云上自主建站:模板化设计与智能工具打造高效网站
如何通过WDCP绑定主域名及创建子域名站点?
佛山企业网站制作公司有哪些,沟通100网上服务官网?
h5在线制作网站电脑版下载,h5网页制作软件?
如何通过.red域名打造高辨识度品牌网站?
天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?
盘锦网站制作公司,盘锦大洼有多少5G网站?
C++如何编写函数模板?(泛型编程入门)
北京的网站制作公司有哪些,哪个视频网站最好?
Python路径拼接规范_跨平台处理说明【指导】
*请认真填写需求信息,我们会在24小时内与您取得联系。