跟我学AngularJs:Service、Factory、Provider依赖注入使用与差别 一、Service使用具体解释 二、Factory使用具体解释 三、provider使用具体解释 四、Service、Factory、Provider三者差别

     林炳文Evankaka原创作品。

转载请注明出处http://blog.csdn.net/evankaka

       本教程使用AngularJs版本号:1.5.3

       AngularJs GitHub: https://github.com/angular/angular.js/

       AngularJs下载地址:https://angularjs.org/

         用有过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用来定义路由信息等。内置的服务总是前缀$符号。

      当中。三者的关系能够看成是下图:

跟我学AngularJs:Service、Factory、Provider依赖注入使用与差别
一、Service使用具体解释
二、Factory使用具体解释
三、provider使用具体解释
四、Service、Factory、Provider三者差别

(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(内联注解。推荐使用):

 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使用实例 

一个完整实例:

<!DOCTYPE html>
<html lang="zh" ng-app="myApp">
<head>
    <meta charset="UTF-8">
    <title>AngularJS学习</title>
    <script type="text/javascript" src="./1.5.3/angular.min.js"></script>
</head>
<body>
    <div ng-controller="myCtrl">
        <button ng-click="getPrivate()">按钮一</button>
        <button ng-click="getPUbluc()">按钮二</button>
    </div>
    <div ng-controller = "myCtrl2">
    </div>
</body>
<script type="text/javascript">
var app = angular.module('myApp', []);
app.controller('myCtrl', function($scope, myService) {
    $scope.getPrivate = function() {
        alert(myService.getPrivate());
    };
    $scope.getPUbluc = function() {
        alert(myService.variable);
    };
});
app.controller('myCtrl2', function($scope, myService) {

});
app.service('myService', function() {
     console.log('instance myService');
    var privateValue = "I am Private";
    this.variable = "This is public";
    this.getPrivate = function() {
        return privateValue;
    };
});
</script>
</html>
效果例如以下:

跟我学AngularJs:Service、Factory、Provider依赖注入使用与差别
一、Service使用具体解释
二、Factory使用具体解释
三、provider使用具体解释
四、Service、Factory、Provider三者差别
另外,从这里能够看到两个controller注入同一个service,可是终于仅仅实例化了一次!

跟我学AngularJs:Service、Factory、Provider依赖注入使用与差别
一、Service使用具体解释
二、Factory使用具体解释
三、provider使用具体解释
四、Service、Factory、Provider三者差别

注意:seivce定义的服务不能在.config中使用。仅仅有provider定义的才干够

二、Factory使用具体解释

Factory 一般就是创建一个对象,然后在对这个对象加入方法与数据,最后将些对象返回就可以。然后注入到Controller层中就可以。

使用实例:
<!DOCTYPE html>
<html lang="zh" ng-app="myApp">
<head>
    <meta charset="UTF-8">
    <title>AngularJS学习</title>
    <script type="text/javascript" src="./1.5.3/angular.min.js"></script>
</head>
<body>
    <div ng-controller="myCtrl">
        <button ng-click="getPrivate()">按钮一</button>
        <button ng-click="getPUbluc()">按钮二</button>
    </div>
    <div ng-controller = "myCtrl2">
    </div>
</body>
<script type="text/javascript">
var app = angular.module('myApp', []);
app.controller('myCtrl', function($scope, myFactory) {
    $scope.getPrivate = function() {
        alert(myFactory.getPrivate());
    };
    $scope.getPUbluc = function() {
        alert(myFactory.variable);
    };
});
app.controller('myCtrl2', function($scope, myFactory) {

});
app.factory('myFactory', function() {
    console.log('instance myFactory');
    var factory = {};
    var privateValue = "I am Private";
    factory.variable = "This is public";
    factory.getPrivate = function() {
        return privateValue;
    };
    return factory;
});
</script>
</html>
效果:
跟我学AngularJs:Service、Factory、Provider依赖注入使用与差别
一、Service使用具体解释
二、Factory使用具体解释
三、provider使用具体解释
四、Service、Factory、Provider三者差别

从以下能够看到仅仅实例化了一次,两下Controller注入同一个factory,可是终于仅仅实例化了一次!
跟我学AngularJs:Service、Factory、Provider依赖注入使用与差别
一、Service使用具体解释
二、Factory使用具体解释
三、provider使用具体解释
四、Service、Factory、Provider三者差别
记得一定要return一个Object对象,否则会报例如以下错误:
跟我学AngularJs:Service、Factory、Provider依赖注入使用与差别
一、Service使用具体解释
二、Factory使用具体解释
三、provider使用具体解释
四、Service、Factory、Provider三者差别

AngularJS中的Services:

三、provider使用具体解释

    $provide服务负责告诉Angular怎样创造一个新的可注入的东西:即服务。服务会被叫做供应商的东西来定义,你能够使用$provide来创建一个供应商。

你须要使用$provide中的provider()方法来定义一个供应商。同一时候你也能够通过要求$provide被注入到一个应用的config函数中来获得$provide服务。使用方法是返回一个$get函数。注意在config阶段,仅仅有provider能被注入。

其他使用方法和service一样。

以下是一个实例。
<!DOCTYPE html>
<html lang="zh" ng-app="myApp">
<head>
    <meta charset="UTF-8">
    <title>AngularJS学习</title>
    <script type="text/javascript" src="./1.5.3/angular.min.js"></script>
</head>
<body>
    <div ng-controller="myCtrl1">
        <button ng-click = "onclick1()">请点击我1</button>
    </div>
    <div ng-controller="myCtrl2">
         <button ng-click = "onclick2()">请点击我2</button>
    </div>
</body>
<script type="text/javascript">
var app = angular.module('myApp', []);
app.controller('myCtrl1', function($scope, testProvider) {
    $scope.onclick1 = function() {
        testProvider("林炳文Evankaka");
    };
});
app.controller('myCtrl2', function($scope , testProvider) {
      $scope.onclick2 = function() {
        testProvider("我究竟是谁");
    };
});

app.provider('testProvider', function(){
    console.log('instance testProvider');
    var f = function(name) {
       alert("Hello, " + name);
    };
    this.$get = function(){ //一定要有!

return f; }; }); </script> </html>

效果:
跟我学AngularJs:Service、Factory、Provider依赖注入使用与差别
一、Service使用具体解释
二、Factory使用具体解释
三、provider使用具体解释
四、Service、Factory、Provider三者差别
从以下能够看到仅仅实例化了一次:
跟我学AngularJs:Service、Factory、Provider依赖注入使用与差别
一、Service使用具体解释
二、Factory使用具体解释
三、provider使用具体解释
四、Service、Factory、Provider三者差别
再来做一个provider实例化的时间測试:
<!DOCTYPE html>
<html lang="zh" ng-app="myApp">

<head>
    <meta charset="UTF-8">
    <title>AngularJS学习</title>
    <script type="text/javascript" src="./1.5.3/angular.min.js"></script>
</head>

<body>
    <div ng-controller="myCtrl1">
        <button ng-click="onclick1()">请点击我1</button>
    </div>
    <div ng-controller="myCtrl2">
        <button ng-click="onclick2()">请点击我2</button>
    </div>
</body>
<script type="text/javascript">
var app = angular.module('myApp', []);
app.controller('myCtrl1', function($scope) {
/*    $scope.onclick1 = function() {
        test("林炳文Evankaka");
    };*/
});
app.controller('myCtrl2', function($scope) {
/*    $scope.onclick2 = function() {
        test("我究竟是谁");
    };*/
});
app.provider('test', function() {
    console.log('instance test');
    var f = function(name) {
        alert("Hello, " + name);
    };
    this.$get = function() { //一定要有!

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>

跟我学AngularJs:Service、Factory、Provider依赖注入使用与差别
一、Service使用具体解释
二、Factory使用具体解释
三、provider使用具体解释
四、Service、Factory、Provider三者差别
页面刷新后,我们发现即使不注入这个providrer。但也它也进行实例化了,而service/factory则是第一次注入时才会初始化。而也这是为什么它能够注入到config的一个原因吧!
什么时候使用provider()方法

(1)当我们希望在应用開始前对service进行配置的时候就须要使用到provider()。例如。我们须要配置services在不同的部署环境里面(开发,演示。生产)使用不同的后端处(2)理的时候就能够使用到了
当我们打算公布开源provider()也是首选创建service的方法。这样就能够使用配置的方式来配置services而不是将配置数据硬编码写到代码里面。


四、Service、Factory、Provider三者差别


1) 用 Factory 就是创建一个对象。为它加入属性,然后把这个对象返回出来。

你把 service 传进 controller 之后,在 controller 里这个对象里的属性就能够通过 factory 使用了。


2) Service 是用"new"keyword实例化的。因此,你应该给"this"加入属性,然后 service 返回"this"。

你把 service 传进 controller 之后,在controller里 "this" 上的属性就能够通过 service 来使用了。

3) Providers 是唯一一种你能够传进 .config() 函数的 service。当你想要在 service 对象启用之前,先进行模块范围的配置,那就应该用 provider。


4)Factory/service是第一个注入时才实例化,而provider不是,它是在config之前就已实例 化好
同一函数三种不同写法:
<!DOCTYPE html>
<html lang="zh" ng-app="myApp">
<head>
    <meta charset="UTF-8">
    <title>AngularJS学习</title>
    <script type="text/javascript" src="./1.5.3/angular.min.js"></script>
</head>
<body>
    <div ng-controller="myCtrl">
        <p>{{ output1 }}</p>
        <p>{{ output2 }}</p>
        <p>{{ output3 }}</p>
    </div>
    <div ng-controller="myCtrl2">
    </div>
</body>
<script type="text/javascript">
var app = angular.module('myApp', []);
app.controller('myCtrl', function($scope,testService, testFactory, testProvider) {
    $scope.output1 = testService.lable;
    $scope.output2 = testFactory.lable();
    $scope.output3 = testProvider;
});
app.controller('myCtrl2', function($scope,testService, testFactory, testProvider) {
});
app.service('testService',function(){
      console.log('instance testService');
     this.lable = 'this is service';
});
app.factory('testFactory', function () {
      console.log('instance testFactory');
     return{
        lable: function(){
        return 'this is factory';
        }
    };
});
app.provider('testProvider', function(){
    console.log('instance testProvider');
    this.$get = function(){
        return 'this is provider';
    };
});
</script>
</html>


跟我学AngularJs:Service、Factory、Provider依赖注入使用与差别
一、Service使用具体解释
二、Factory使用具体解释
三、provider使用具体解释
四、Service、Factory、Provider三者差别
看console的输出,能够知道都仅仅实例 化了一次:
跟我学AngularJs:Service、Factory、Provider依赖注入使用与差别
一、Service使用具体解释
二、Factory使用具体解释
三、provider使用具体解释
四、Service、Factory、Provider三者差别


參考文章:
http://www.cnblogs.com/wushangjue/p/4533953.html?utm_source=tuicool&utm_medium=referral
http://www.oschina.net/translate/angularjs-factory-vs-service-vs-provider
http://my.oschina.net/tanweijie/blog/295067
http://www.360doc.com/content/15/1010/18/28162318_504719466.shtml