AngularJs Creating Services詳解及範例程式碼_AngularJS

來源:互聯網
上載者:User

雖然angular提供許多有用的service,在一些特別的應用中,我們會發現編寫自訂service是很有用的。如果我們想做這件事,我們首先要在module中註冊一個serviceFactory 方法,可以通過Module.factory api(http://docs.angularjs.org/api/angular.module)或者在module配置方法中直接通過$provide api(http://docs.angularjs.org/api/AUTO.$provide)。

  所有angular service都參與到DI(http://www.jb51.net/article/91775.htm)中,既可以通過angular DI系統(injector)中使用名稱(id)註冊自己,也可以通過在其他Factory 方法中聲明對已存在的service的依賴。

一、Registering Services

  為了註冊一個service,我們必須擁有一個module,並且使這個server成為這個module的一部分。然後,我們可以通過Module api或者在module配置函數中註冊service。下面的虛擬碼將展示這兩種註冊方式。

  使用angular.module api:

var myModule = angular.module(‘myModule',[]);myModule.factory(‘serviceId',function() {  var someService;  //Factory 方法體,構建someService  return someService;});

  使用$provide service:

angular.module(‘myModule',[],function($provide) {  $provide.factory(‘serviceId',function() {    var someService;    //Factory 方法體,構建someService    return someService;  });}); 

  注意,我們無須註冊一個服務執行個體,相反地,Factory 方法會在它被調用的時候被執行個體化。

二、Dependencies

  service不僅僅可以被依賴,更可以擁有自己的依賴。可以在Factory 方法的參數中指定依賴。閱讀(http://www.jb51.net/article/91775.htm)更多關於angular中的DI、數組標記的用途和$inject屬性,讓DI聲明更加簡潔。(Read more about the DI in Angular and the use of array notation and $inject property to make DI annotation minification-proof……)

  下面是一個非常簡單的service例子。這個服務依賴$window service(通過Factory 方法參數傳遞),而且只有一個方法。這個service簡單地儲存所有通知,在第三個之後,這個service會通過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都是延遲執行個體化的(lazily)。這意味著service僅僅在其他依賴它的已執行個體化的service或者應用組件中被依賴時,才會建立。換句話說,angular直到服務被直接或者間接請求時候,才會執行個體化service。

四、Services as singletons

  最後,我們必須意識到所有angular service都是一個單例應用。這意味著每一個injector中有且只有一個給定service的執行個體。由於angular是極其討厭破壞global state的,所以建立多個injector,使每一個都有指定service的執行個體是可行的,除了在測試中有強烈的需求外,一般很少有這樣的需要。

 以上就是關於Angular Services 的資料整理,後續繼續補充相關資料,謝謝大家對本站的支援!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.