一. 首先说一下,为什么要引入Factory,Service和Provider这三个Service层。

1.因为我们不应该在controller层写入大量的业务逻辑和持久化数据,controller层越轻薄越好,业务逻辑和持久化数据应该放在Service层。

2.针对内存性能的考虑,controller会在需要的时候才初始化,不需要的话,就会被放弃。所以AngularJS会在刷新页面的时候,清空controller. 而永久保存的数据放在Service层,那么在不同的controller之间可以被调用。

二.AngularJS 提供了三种方法创建并注册自己的Service.

1). Factory

2). Service

3). Provider

三.对Factory,Service,Provider的详解

1).Factory 相当于创建对象,在对象里添加属性和方法,返回这个对象,然后在controller里便可直接用service对象的属性啦

例如:

<!DOCTYPE html>
<html>
<head>
<title></title>
<meta charset="utf-8" />
<script type="text/javascript" src="js/angular.js"></script>
<script type="text/javascript" src="js/demo1.js"></script>
</head>
<body data-ng-app="demoApp">
<div data-ng-controller="demoController">
title:<span data-ng-bind="title"></span>
</div>
</body>
</html> (function () {
angular.module('demoApp', []);
angular.module('demoApp').controller("demoController", function ($scope,demoFactory) {
$scope.title = demoFactory.getTitle();
});
angular.module('demoApp').factory("demoFactory", function () {
var _title = "ruby's test";
var service = {};
service.getTitle = function () {
return _title;
}
return service;
})
})();

 2).Service 相当于是用new关键字来实例化的Service对象(相当于创建了一个构造器),因此只需要给this添加属性,然后由service返回this. 在controller层通过该service获得这个属性。

angular.module('demoApp').controller("demoController", function ($scope,demoService) {
$scope.title = demoService.getTitle();
});
angular.module('demoApp').service('demoService', function () {
var _title = "Ruby Test service";
this.getTitle = function () {
return _title;
}
});

3).Provider 是唯一一个能传到应用程序.config的服务。所以当想要在controller之前启用,先进行模块范围的配置(对provider的一部分属性值进行配置),就用provider

  如果想要在controller控制器里直接调用provider的属性和方法 要放到$get里

<!DOCTYPE html>
<html>
<head>
<title></title>
<meta charset="utf-8" />
<script type="text/javascript" src="js/angular.js"></script>
<script type="text/javascript" src="js/demo1.js"></script>
</head>
<body data-ng-app="demoApp">
<div data-ng-controller="demoController">
title:<span data-ng-bind="title"></span>
<br/>
thingFromConfig:<span data-ng-bind="thingFromConfig"></span>
</div>
</body>
</html> angular.module('demoApp', []);
angular.module('demoApp').controller("demoController", function ($scope,demoProvider) {
demoProvider.setTitle("provider service test");
$scope.title = demoProvider.getTitle();
$scope.thingFromConfig = demoProvider.thingOnConfig;
});
angular.module('demoApp').provider('demoProvider', function () {
var _title = "";
this.thingFromConfig = "";
this.$get = function () {
return {
setTitle: function (t) {
_title = t;
},
getTitle: function () {
return _title;
},
thingOnConfig: this.thingFromConfig
}
}
});
angular.module('demoApp').config(function (demoProviderProvider) {
demoProviderProvider.thingFromConfig = "Hello, this is a thing from configuration.";
});

四.深入解析 AngularJs的service

首先了解一下$provide

AngularJs有个叫$provide的服务,这个服务可以创建供应商,我们的service都是通过供应商来定义的。

有六个个创建供应商的方法:

1.Factory

2.Service

3.Constant

4.value

5.provider

6.decorator(装饰器)

AngularJS 讲解五, Factory ,Service , Provider的更多相关文章

  1. angularjs factory,service,provider 自定义服务的不同

    angularjs框架学了有一段时间了,感觉很好用.可以把angularjs的app理解成php的class,controller是控制器,而内置服务和自定义服务就可以理解成models了.angul ...

  2. angularjs 中 Factory,Service,Provider 之间的区别

    本片文章是使用了 angularjs 中使用 service 在controller 之间 share 对象和数据 的code(http://jsfiddle.net/kn46u0uj/1/) 来进行 ...

  3. [译]AngularJS中几种Providers(Factory, Service, Provider)的区别

    原文: http://blog.xebia.com/2013/09/01/differences-between-providers-in-angularjs/ 什么是Provider? Angula ...

  4. AngularJS Factory Service Provider

    先看看http://www.cnblogs.com/mbydzyr/p/3460501.html http://www.oschina.net/translate/angularjs-factory- ...

  5. angula的factory service provider

    本人学了一段时间的angular的服务(factory.service.provider),有了自己的一些对于他们的见解,如果说的对,敬请赐教!!! 以后更新

  6. Angular之Providers (Value, Factory, Service and Constant )

    官方文档Providers Each web application you build is composed of objects that collaborate to get stuff do ...

  7. Angular1.x 之Providers (Value, Factory, Service and Constant )

    官方文档Providers Each web application you build is composed of objects that collaborate to get stuff do ...

  8. AngularJs:Service、Factory、Provider依赖注入使用与区别

           本教程使用AngularJS版本:1.5.3        AngularJs GitHub: https://github.com/angular/angular.js/       ...

  9. 转载:[AngularJS系列] 那伤不起的provider们啊~ (Provider, Value, Constant, Service, Factory, Decorator)

    来源:http://hellobug.github.io/blog/angularjs-providers/ 用AngularJS做项目,但凡用过什么service啊,factory啊,provide ...

随机推荐

  1. xshell 图形化连接ubuntu

    原文: http://jingyan.baidu.com/article/d45ad148967fcd69552b80f6.html Xmanager4系列软件是一套非常好的liunx远程操作,尤其是 ...

  2. javascript中的原型继承

    在Javascript面向对象编程中,原型继承不仅是一个重点也是一个不容易掌握的点.在本文中,我们将对Javascript中的原型继承进行一些探索. 基本形式 我们先来看下面一段代码: <cod ...

  3. 关于css3的calc()

    么是calc()? 学习calc()之前,我们有必要先知道calc()是什么?只有知道了他是个什么东东?在实际运用中更好的使用他. calc()从字面我们可以把他理解为一个函数function.其实c ...

  4. 【HighCharts系列教程】六、去除highCharts版权信息的几种方法

    方法一:单个图表去除版权 设置Credits属性为不可用,也就是credits中enable=false,具体代码如下 <script type="text/javascript&qu ...

  5. fixed定位与absolute定位

    相同点: 1.fixed定位和absolute定位都是绝对定位 2.fixed定位和absolute定位都脱离了标准文档流, 3.未设置偏移量时,都定位在父元素的左上角 tip:元素设置相对定位或绝对 ...

  6. 程序ajax请求公共组件:app-jquery-http.js

    // --------网络操作-------------------- $.HTTP = { getUrlParam : function(name) { var reg = new RegExp(& ...

  7. phpcms v9 在当前栏目下获取父栏目与当前栏目的名称与连接

    <a href="#" target="_blank">首页</a> > <a href="{$CATEGORYS ...

  8. DIV 和 SPAN 区别

    DIV 和 SPAN 元素最大的特点是默认都没有对元素内的对象进行任何格式化渲染.主要用于应用样式表(共同点). 两者最明显的区别在于DIV是块元素,而SPAN是行内元素(也译作内嵌元素). 详解:1 ...

  9. checkbox选择多数据传入后台时,怎样解析数据

    <input type="checkbox" name="test" value="值1" />显示的内容<input t ...

  10. Keil C 里面Lib库文件的生成与调用

    源:Keil C 里面Lib库文件的生成与调用