转自:http://blog.csdn.net/ywl570717586/article/details/51306176

初学 AngularJS 时, 肯定会对其提供 factory 、 service 和 provider 感到疑惑, 这三种都是提供服务的方式, 他们到底有什么区别呢?

factory

factory 可以认为是设计模式中的工厂方法, 就是你提供一个方法, 该方法返回一个对象的实例, 对于 AngularJS 的 factory 来说, 就是先定义一个对象, 给这个对象添加属性和方法, 然后返回这个对象, 例如:

var app = angular.module('MyApp', []);  

app.factory('MyFactory', function() {
// define result object of factory.
var result = {};
// add some property and method to the object
result.greeting = 'Hello from factory.';
// return the object;
return result;
});

lain copy

最后 controller 拿到的就是 result 对象, 相当于下面的代码:

[javascript] view plain copy

 

  1. var factoryResult = MyFactory();

所谓的 factory 就是这么简单。

service

service 通过 new 运算符进行实例化, 可以认为是一个类型, 只要把属性和方法添加到 this 对象上即可, 不用显式返回什么对象, 比如下面的代码:

[javascript] view plain copy

 

  1. app.service('MyService', function() {
  2. this.greeting = 'Hello from service';
  3. });

controller 拿到的对象就是上面代码中 this 指向的对象, 相当于下面的代码:

[javascript] view plain copy

 

  1. var serviceObj = new MyService();

provider

与 factory 和 service 稍有不同的是, provider 必须提供一个 $get 方法, $get 方法和 factory 要求是一致的, 即: 先定义一个对象, 给这个对象添加属性和方法, 然后返回这个对象, 例如:

[javascript] view plain copy

 

  1. app.provider('MyProvider', function() {
  2. this.$get = function() {
  3. var result = {};
  4. result.greeting = 'Hello from provider';
  5. return result;
  6. }
  7. })

最后 controller 拿到的对象就是 provider 的 $get 方法返回的对象, 相当于下面的代码:

[javascript] view plain copy

 

  1. var instance = new MyProvider();
  2. var provider = instance.$get();

使用 factory、 service 与 provider

factory、 service 与 provider 使用起来是一样的, 都是通过 AngularJS 的依赖注入使用, 比如:

[javascript] view plain copy

 

  1. // inject factory, service and provider to a controller
  2. app.controller('TestController', ['$scope', 'MyFactory', 'MyService', 'MyProvider', function($scope, myFactory, myService, myProvider) {
  3. $scope.greetingFromFactory = myFactory.greeting;
  4. $scope.greetingFromService = myService.greeting;
  5. $scope.greetingFromProvider = myProvider.greeting;
  6. }]);

对应的 HTML 视图为:

[html] view plain copy

 

  1. <body ng-controller="TestController">
  2. <p>greeting from factory: {{greetingFromFactory}} </p>
  3. <p>greeting from service: {{greetingFromService}} </p>
  4. <p>greeting from provider: {{greetingFromProvider}} </p>
  5. </body>

provider 可以在应用启动时进行配置

provider 的特殊之处就是可以在 module 启动时进行配置, 从而达到特殊的用途, 比如在上面的 provider 中可以添加一个 setName 方法, 可以在启动时调用这个方法, 进行一些额外的初始化工作:

[javascript] view plain copy

 

  1. app.provider('MyProvider', function() {
  2. // default name is 'anonymous';
  3. var defaultName = 'anonymous';
  4. var name = defaultName;
  5. // setName can be called duaring module init
  6. this.setName = function(newName) {
  7. name = newName;
  8. }
  9. this.$get = function() {
  10. var result = {};
  11. result.greeting = 'Hello from provider';
  12. result.name = name;
  13. result.defaultName = defaultName;
  14. return result;
  15. }
  16. })

添加了 setName 方法之后, 可以 module 启动时来调用这个方法, 实现对 provider 的配置

[javascript] view plain copy

 

  1. app.config(function(MyProviderProvider) {
  2. MyProviderProvider.setName('Angularjs Provider');
  3. });

在 controller 中添加显示 provider 的这些信息:

[html] view plain copy

 

  1. app.controller('TestController', ['$scope', 'MyFactory', 'MyService', 'MyProvider', function($scope, myFactory, myService, myProvider) {
  2. $scope.greetingFromFactory = myFactory.greeting;
  3. $scope.greetingFromService = myService.greeting;
  4. $scope.greetingFromProvider = myProvider.greeting;
  5. $scope.defaultName = myProvider.defaultName;
  6. $scope.name = myProvider.name
  7. }]);

对应的 HTML 视图也调整一下

[html] view plain copy

 

  1. <body ng-controller="TestController">
  2. <p>greeting from factory: {{greetingFromFactory}} </p>
  3. <p>greeting from service: {{greetingFromService}}</p>
  4. <p>greeting from provider: {{greetingFromProvider}} </p>
  5. <p>defaultName: {{defaultName}}, config to: {{name}} </p>
  6. </body>

最后程序运行截图如下:

AngularJS 中的 factory、 service 和 provider区别,简单易懂的更多相关文章

  1. AngularJS 讲解五, Factory ,Service , Provider

    一. 首先说一下,为什么要引入Factory,Service和Provider这三个Service层. 1.因为我们不应该在controller层写入大量的业务逻辑和持久化数据,controller层 ...

  2. AngularJS进阶(三十三)书海拾贝之简介AngularJS中使用factory和service的方法

    简介AngularJS中使用factory和service的方法 AngularJS支持使用服务的体系结构"关注点分离"的概念.服务是JavaScript函数,并负责只做一个特定的 ...

  3. angularjs中factory, service和provider

    在Angular里面,services作为单例对象在需要到的时候被创建,只有在应用生命周期结束的时候(关闭浏览器)才会被清除.而controllers在不需要的时候就会被销毁了(因为service的底 ...

  4. 简介AngularJS中使用factory和service的方法

    AngularJS支持使用服务的体系结构“关注点分离”的概念.服务是JavaScript函数,并负责只做一个特定的任务.这也使得他们即维护和测试的单独实体.控制器,过滤器可以调用它们作为需求的基础.服 ...

  5. 我也谈“the difference between Factory, Service, and Provider in Angular”

    看完这篇文章之后的理解与实践:原文地址:http://tylermcginnis.com/angularjs-factory-vs-service-vs-provider/ <!doctype ...

  6. CommonJS, AMD, CMD是什么及区别--简单易懂有实例

    CommonJS, AMD, CMD都是JS模块化的规范. CommonJS是服务器端js模块化的规范,NodeJS是这种规范的实现. AMD(异步模块定义)和CMD(通用模块定义)都是浏览器端js模 ...

  7. AngularJS 之 Factory vs Service vs Provider【转】

    英文原文:AngularJS: Factory vs Service vs Provider 当你初试 Angular 时,很自然地就会往 controller 和 scope 里堆满不必要的逻辑.一 ...

  8. AngularJS之Factory vs Service vs Provider

    原文  http://www.linuxeden.com/html/news/20140509/151538.html 当你初试 Angular 时,很自然地就会往 controller 和 scop ...

  9. [转载]AngularJS之Factory vs Service vs Provider

    http://www.oschina.net/translate/angularjs-factory-vs-service-vs-provider http://tylermcginnis.com/a ...

随机推荐

  1. 【FJWC 2019】min

    [FJWC 2019]min 题目描述 给你一张 \(n\) 个点 \(m\) 条边的无向图,走过每条边都需要花费 \(1\) 秒. 给你一个整数 \(k\) ,请你选择至多 \(k\) 个点,令经过 ...

  2. 7.01-beautiful_soup

    # pip install beautifulsoup4 from bs4 import BeautifulSoup html_doc = """ <html> ...

  3. 自己动手写处理器之第二阶段(1)——可编程逻辑器件与PLD电路设计流程

    将陆续上传本人写的新书<自己动手写处理器>(尚未出版),今天是第五篇,我尽量每周四篇         通过上一章的介绍,读者应该知道CPU内部有一些主要的电路,比方:译码电路.运算电路.控 ...

  4. 转://Oracle undo 自动调优

    Oracle 10gr2的后续版本中添加了UNDO信息最短保留时间段自动调优的特性,不再仅仅依据参数UNDO_RETENTION的设定,其调优原则如下:1. 当UNDO TABLESPACE为 fix ...

  5. Armitage攻击winxp——P201421410029

    实验简介 实验所属系列: 安全工具使用 实验对象:本科/专科信息安全专业 相关课程及专业: linux基础.网络安全 实验类别: 实践实验类 预备知识 Armitage基本介绍       Armit ...

  6. jQuery和js之Cookie实现

    Web开发者的朋友们基本上都知道,jQuery是对js的封装.今天之所以想讲解这个问题,主要是因为Cookie用的还是比较多,应用场景除了老生常谈的购物车,还有就是用户状态(以我之前开发的一个项目除了 ...

  7. 项目Alpha冲刺4

    作业描述 课程: 软件工程1916|W(福州大学) 作业要求: 项目Alpha冲刺(团队) 团队名称: 火鸡堂 作业目标: 介绍第四天冲刺的项目进展.问题困难和心得体会 1.团队信息 队名:火鸡堂 队 ...

  8. Java 数据类型总结

    Java 中提供了八种数据类型:6个数字类型(四个整数型,两个浮点型).字符类型.布尔型. 依次分别是 : byte.int.short.long.float.double.char.boolean. ...

  9. SVM-笔记(1)

    1 目的 SVM推导是从讨论最优超平面开始的,即为了得到一个能够划分不同超平面的面,即公式1: \begin{equation}w^Tx+b=0 \tag{1} \end{equation} 这个公式 ...

  10. SCOI2019d1t1平台跳跃[高精]

    分析 首先考虑相邻柱子之间没有浮台. 记前 \(m-1\) 个盘子为 x, 第 \(m\) 个盘子为 y,有如下过程:\(x\rightarrow C, y\rightarrow B, x\right ...