AngularJs Creating Services詳解及示例代碼
雖然angular提供許多有用的service,在一些特別的應(yīng)用中,我們會(huì)發(fā)現(xiàn)編寫自定義service是很有用的。如果我們想做這件事,我們首先要在module中注冊(cè)一個(gè)service工廠方法,可以通過(guò)Module.factory api(http://docs.angularjs.org/api/angular.module)或者在module配置方法中直接通過(guò)$provide api(http://docs.angularjs.org/api/AUTO.$provide)。
所有angular service都參與到DI(http://www.dhdzp.com/article/91775.htm)中,既可以通過(guò)angular DI系統(tǒng)(injector)中使用名稱(id)注冊(cè)自己,也可以通過(guò)在其他工廠方法中聲明對(duì)已存在的service的依賴。
一、Registering Services
為了注冊(cè)一個(gè)service,我們必須擁有一個(gè)module,并且使這個(gè)server成為這個(gè)module的一部分。然后,我們可以通過(guò)Module api或者在module配置函數(shù)中注冊(cè)service。下面的偽代碼將展示這兩種注冊(cè)方式。
使用angular.module api:
var myModule = angular.module(‘myModule',[]);
myModule.factory(‘serviceId',function() {
var someService;
//工廠方法體,構(gòu)建someService
return someService;
});
使用$provide service:
angular.module(‘myModule',[],function($provide) {
$provide.factory(‘serviceId',function() {
var someService;
//工廠方法體,構(gòu)建someService
return someService;
});
});
注意,我們無(wú)須注冊(cè)一個(gè)服務(wù)實(shí)例,相反地,工廠方法會(huì)在它被調(diào)用的時(shí)候被實(shí)例化。
二、Dependencies
service不僅僅可以被依賴,更可以擁有自己的依賴??梢栽诠S方法的參數(shù)中指定依賴。閱讀(http://www.dhdzp.com/article/91775.htm)更多關(guān)于angular中的DI、數(shù)組標(biāo)記的用途和$inject屬性,讓DI聲明更加簡(jiǎn)潔。(Read more about the DI in Angular and the use of array notation and $inject property to make DI annotation minification-proof……)
下面是一個(gè)非常簡(jiǎn)單的service例子。這個(gè)服務(wù)依賴$window service(通過(guò)工廠方法參數(shù)傳遞),而且只有一個(gè)方法。這個(gè)service簡(jiǎn)單地儲(chǔ)存所有通知,在第三個(gè)之后,這個(gè)service會(huì)通過(guò)window.alert顯示所有通知。
<!DOCTYPE HTML>
<html lang="zh-cn" ng-app="MainApp">
<head>
<meta charset="UTF-8">
<title>services</title>
</head>
<body>
<div ng-controller="MyController">
<input type="text" ng-model="msg"/>
<button ng-click="saveMsg()">save msg</button>
<ul>
<li ng-repeat="msg in msgs">{{msg}}</li>
</ul>
</div>
<script src="../angular-1.0.1.js" type="text/javascript"></script>
<script type="text/javascript">
var app = angular.module("MainApp",[],function($provide) {
$provide.factory("notify",["$window","$timeout",function(win,timeout) {
var msgs = [];
return function(msg) {
msgs.push(msg);
if(msgs.length==3) {
timeout(function() {
win.alert(msgs.join("\n"));
msgs = [];
},10);
}
}
}])
});
app.controller("MyController",function($scope,notify) {
$scope.msgs = [];
$scope.saveMsg = function() {
this.msgs.push(this.msg);
notify(this.msg);
this.msg = "";
};
});
</script>
</body>
</html>
三、Instantiating Angular Services
所有在angular中的service都是延遲實(shí)例化的(lazily)。這意味著service僅僅在其他依賴它的已實(shí)例化的service或者應(yīng)用組件中被依賴時(shí),才會(huì)創(chuàng)建。換句話說(shuō),angular直到服務(wù)被直接或者間接請(qǐng)求時(shí)候,才會(huì)實(shí)例化service。
四、Services as singletons
最后,我們必須意識(shí)到所有angular service都是一個(gè)單例應(yīng)用。這意味著每一個(gè)injector中有且只有一個(gè)給定service的實(shí)例。由于angular是極其討厭破壞global state的,所以創(chuàng)建多個(gè)injector,使每一個(gè)都有指定service的實(shí)例是可行的,除了在測(cè)試中有強(qiáng)烈的需求外,一般很少有這樣的需要。
以上就是關(guān)于Angular Services 的資料整理,后續(xù)繼續(xù)補(bǔ)充相關(guān)資料,謝謝大家對(duì)本站的支持!
- AngularJS入門教程之服務(wù)(Service)
- angularJS Provider、factory、service詳解及實(shí)例代碼
- 簡(jiǎn)介AngularJS中使用factory和service的方法
- 簡(jiǎn)介AngularJS中$http服務(wù)的用法
- AngularJS中$http服務(wù)常用的應(yīng)用及參數(shù)
- Angularjs 自定義服務(wù)的三種方式(推薦)
- AngularJs自定義服務(wù)之實(shí)現(xiàn)簽名和加密
- AngularJS 服務(wù)詳細(xì)講解及示例代碼
- AngularJS入門教程之REST和定制服務(wù)詳解
- AngularJS通過(guò)$http和服務(wù)器通信詳解
- AngularJS服務(wù)service用法總結(jié)
相關(guān)文章
Angularjs自定義指令實(shí)現(xiàn)分頁(yè)插件(DEMO)
由于最近的一個(gè)項(xiàng)目使用的是angularjs1.0的版本,涉及到分頁(yè)查詢數(shù)據(jù)的功能,后來(lái)自己就用自定義指令實(shí)現(xiàn)了該功能,下面小編把實(shí)例demo分享到腳本之家平臺(tái),需要的朋友參考下2017-09-09
Agularjs妙用雙向數(shù)據(jù)綁定實(shí)現(xiàn)手風(fēng)琴效果
最近在工作總遇到需要實(shí)現(xiàn)類似手風(fēng)琴效果的需求,下面小編通過(guò)本文給大家分享angularjs巧用雙向數(shù)據(jù)綁定實(shí)現(xiàn)手風(fēng)琴效果,需要的朋友可以參考下2017-05-05
angular多選表單數(shù)據(jù)綁定的簡(jiǎn)單嘗試
AngularJS中數(shù)據(jù)綁定相信大家應(yīng)該都不陌生了,這篇文章主要給大家介紹了關(guān)于angular多選表單數(shù)據(jù)綁定的簡(jiǎn)單嘗試,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05
Angular directive遞歸實(shí)現(xiàn)目錄樹結(jié)構(gòu)代碼實(shí)例
本篇文章主要介紹了Angular directive遞歸實(shí)現(xiàn)目錄樹結(jié)構(gòu)代碼實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05
Angularjs在初始化未完畢時(shí)出現(xiàn)閃爍問(wèn)題的解決方法分析
這篇文章主要介紹了Angularjs在初始化未完畢時(shí)出現(xiàn)閃爍問(wèn)題的解決方法,結(jié)合實(shí)例形式分析了3種常用的閃爍問(wèn)題解決方法,需要的朋友可以參考下2016-08-08
Angular 實(shí)現(xiàn)輸入框中顯示文章標(biāo)簽的實(shí)例代碼
這篇文章主要介紹了Angular 實(shí)現(xiàn)輸入框中顯示文章標(biāo)簽的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-11-11

