林炳文Evankaka原创作品。
转载请注明出处
本教程使用AngularJs版本号:1.5.3
AngularJs GitHub:
AngularJs下载地址:
用有过Spring的人都知道。Spring的核心思想就是DI(依赖注入,Dependency Injection)和IOC(控制反转 Invension of Controller),AngularJS的service事实上就是用到了这里的DI思想。那么什么叫做DI?
所谓DI,就是指对象是被动接受依赖类而不是自动去找,换句话说就是指对象不是从容器中查找它依赖的类。而是在容器实例化对象的时候主动将它依赖的类注入给它。我个人的理解就是。你在实例化一个类时,它会自动去实例化它里面所用到的其他实例。所以这就叫依赖注入。在Angular里面,services作为单例对象在须要到的时候被创建,仅仅有在应用生命周期结束的时候(关闭浏览器)才会被清除。而controllers在不须要的时候就会被销毁了。
AngualrJs中可用来注入的有三种类型,service、factory、provider,这三种写法不样。使用方法也都不一样。当中。service仅仅实例化一次。事实上就是单例模式的思想。不管我们在什么地方注入我们的service,将永远使用同一个实例。所以对非常多在controller层中的操作就能够放到serivce层中去。
AngularJS提供例如很多内在的服务。如:$http, $route, $window, $location等。每一个服务负责例如一个特定的任务,$http是用来创建AJAX调用,以获得server的数据。
$route用来定义路由信息等。内置的服务总是前缀$符号。
当中。三者的关系能够看成是下图:
一、Service使用具体解释
(1)定义
一个学用的service使用方法例如以下:
一般直接用this来操作数据、定义函数。
app.service('myService', function() { var privateValue = "I am Private"; this.variable = "This is public"; this.getPrivate = function() { return privateValue;};});
(2)AngularJS中使用DI加入Service的三种方法
方式1(内联注解。推荐使用):app.controller('myController', ['$scope', 'dateFilter', function ($scope, dateFilter) { }]);方式2($inject注解):
var MyController = function($scope, dateFilter) {}MyController.$inject = ['$scope', 'dateFilter'];someModule.controller('MyController', MyController);方式3(隐式注解。不推荐使用):
app.controller('myController', function ($scope, dateFilter) { });推荐使用方式1的理由是: 写法上例如法2更简单明了 例如法3更可靠(因为Javascript能够被压缩,AngularJS又是通过解析服务名称找到相应Service的。因此Javascript压缩之后AngularJS将无法找到指定的Service,但字符串不会被压缩,因此单独以字符串指定Service的名称能够避免这个问题) 使用方式1或方式2的注意点: 因为上述第二点原因,AngularJS在编译Html时,由$injector将数组中Service的名称与方法体中的Service进行一一映射。这样的映射关系必须遵守由AngularJS的约定: 数组中Service名称的个数必须与方法体中Service名称的个数一致数组中Service的顺序必须与方法体中Serivce的顺序一致
(3)什么时候适合使用service()方法
service()方法非常适合使用在功能控制比較多的service里面注意:须要使用.config()来配置service的时候不能使用service()方法(4)service使用实例
一个完整实例:
效果例如以下:AngularJS学习
二、Factory使用具体解释
效果:AngularJS学习
三、provider使用具体解释
你须要使用$provide中的provider()方法来定义一个供应商。同一时候你也能够通过要求$provide被注入到一个应用的config函数中来获得$provide服务。使用方法是返回一个$get函数。注意在config阶段,仅仅有provider能被注入。
其他使用方法和service一样。
AngularJS学习
return f; }; }); </script> </html>
效果:AngularJS学习
return f; }; }); /*app.config(function(testProvider) { testProvider('I am config'); });*/ app.config(function($provide) { $provide.provider('greeting', function() { this.$get = function() { return function(name) { alert("Hello," + name); }; }; }); /* greetingProvider('ff');*/ }); </script> </html>
四、Service、Factory、Provider三者差别
你把 service 传进 controller 之后,在 controller 里这个对象里的属性就能够通过 factory 使用了。
你把 service 传进 controller 之后,在controller里 "this" 上的属性就能够通过 service 来使用了。
AngularJS学习 {
{ output1 }}{
{ output2 }}{
{ output3 }}