【AngularJS中的自定义服务service VS factory VS provider】—它们的界别,你驾驭么?

在介绍AngularJS自定义服务在此之前,我们先来打听一下AngularJS~

 

学过HTML的人都清楚,HTML是一门很好的伪静态文本展现设计的申明式语言,可是,要营造WEB应用的话它就体现乏力了。

而AngularJS是为了克制HTML在创设利用上的阙如而安顿的。

AngularJS是一款能够的前端JS框架,已经被用来谷歌的多款产品中间。它有着许多特征,最为宗旨的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等……

AngularJS通过新的属性和表达式扩展了HTML;能够营造三个单一页面应用程序;而且学习起来格外不难。

 

有了上述的问询,我们来看一下AngularJS中的自定义服务。

angularjs中可经过二种办法自定义服务,

分别为$service,$factory,$provider

 

上边作者就给大家各自介绍一下三种AngularJS自定义服务的不一样:

 

一、服务service

 

首先次被注入时实例化,只实例化3次,整个应用的生命周期中是个单例格局,可以用来在controller之间传递数据;

行使new关键字实例化,所以直接选择this定义service,假如你不精通原委,就看看js中的this。
例如:

1 .service('myService', ['', function() {
2 this.getName = function() {
3 return 'CooMark';
4 }
5 }])

 

放到服务:
>>> 使用内置服务,必须在Controller中通过函数的参数注入进来!!!!!

$location:重返当前页面的ULANDL地址。
$http:向服务器发送请求,应用响应服务器传送过来的数据,类似于Ajax
$timeout:相当于setTimeout();
$interval:相当于setInterval();

(参考代码)body部分:

1 <body ng-app="app" ng-controller="ctrl">
2     <p>[功能]<br />
3        {{gongneng}}
4     </p>
5     <p>255转为16进制为:{{num}}</p>
6 </body>

AngularJS, 

(参考代码)JS部分:

先导入JS文件angular.js!!!

1 <script src="libs/angular.js"></script>

 

 2     <script>
 3         angular.module("app",[])
 4         .controller("ctrl",function($scope,$location,$timeout,$interval,$hexafy){
 5             
 6 //          $scope.local = $location.$$absUrl;
 7 //          $scope.local = $location.absUrl();
 8 
 9             $scope.local = $location.$$host;
10             
11             $timeout(function () {
12                 $scope.myHeader = "How are you today?";
13             }, 2000);
14             $scope.num = 0;
15             
16             $interval(function(){
17                 $scope.num ++;
18             },1000);
19             
20             $scope.gongneng = $hexafy.$$gongneng;
21             $scope.hexafy = $hexafy;
22         })
23         
24         /*自定义服务*/
25         .service('$hexafy', function() {
26             this.$$gongneng = "将转入的数字,转为16进制";
27             this.myFunc = function (x) {
28                 return x.toString(16);
29             }
30         })
31         
32         /*自定义过滤器*/
33         .filter("filt",function(){
34             return function(x){
35                 return x.toString(16);
36             }
37         })
38         /*在过滤器中,调用自定义服务*/
39         .filter("filt1",function($hexafy){
40             return function(x){
41                 return $hexafy.myFunc(x);
42             }
43         })
44         
45         
46     </script>

 

二、服务factory

factory是一个函数用于再次回到值,平常大家运用factory函数来计量或重返值。

factory使用上,与service差异十分小。

 

(参考代码)
body部分参考服务Service,JS代码如下:

先导入JS文件angular.js!!!

 1 <script src="libs/angular.js"></script>
 2     <script>
 3         angular.module("app",[])
 4         .config()
 5         .controller("ctrl",function($scope,hexafy){
 6             $scope.gongneng = hexafy.gongneng;
 7             $scope.num = hexafy.myFunc(255);
 8         })
 9         .factory('hexafy',function(){
10             var obj = {
11                 gongneng : "将转入的数字,转为16进制",
12                 myFunc:function(x){
13                     return x.toString(16);
14                 }
15             };
16             return obj;
17         })
18     
19 </script>

 

三、服务provider

壹 、在AngularJS中,瑟维斯,factory都是依据provider落成的。
② 、在provider中,通过$get()方法提供了factory的写法,用于返回value/service/factory。;
叁 、provider是两种自定义服务中,唯一能够写进config配置阶段的一种。

若果服务,必供给在布署阶段推行,那么必须使用provider。不然,一般采纳Service或factory。

 

④ 、扩大:angularjs的借助注入和自定义服务有啥样界别

   
AngularJS实际上是在调用后面出现的代码(就是$provide.provider的本子)。

   
从字面上来说,angularjs的依靠注入和自定义服务基本上无差别。

   
value方法也同样,固然大家须要从$get函数(也正是我们的factory函数)重回的值永远相同的话,

我们能够利用value方法来编排。

 

好了~前天的博客内容就先分享到那边,欢迎留言~

我们一块加油啊!一起学习,一起前行!

 

相关文章