AngularJs Creating Services詳解及示例代碼
雖然angular提供許多有用的service,在一些特別的應用中,我們會發(fā)現(xiàn)編寫自定義service是很有用的。如果我們想做這件事,我們首先要在module中注冊一個service工廠方法,可以通過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.dbjr.com.cn/article/91775.htm)中,既可以通過angular DI系統(tǒng)(injector)中使用名稱(id)注冊自己,也可以通過在其他工廠方法中聲明對已存在的service的依賴。
一、Registering Services
為了注冊一個service,我們必須擁有一個module,并且使這個server成為這個module的一部分。然后,我們可以通過Module api或者在module配置函數(shù)中注冊service。下面的偽代碼將展示這兩種注冊方式。
使用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ù)實例,相反地,工廠方法會在它被調(diào)用的時候被實例化。
二、Dependencies
service不僅僅可以被依賴,更可以擁有自己的依賴??梢栽诠S方法的參數(shù)中指定依賴。閱讀(http://www.dbjr.com.cn/article/91775.htm)更多關(guān)于angular中的DI、數(shù)組標記的用途和$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例子。這個服務(wù)依賴$window service(通過工廠方法參數(shù)傳遞),而且只有一個方法。這個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或者應用組件中被依賴時,才會創(chuàng)建。換句話說,angular直到服務(wù)被直接或者間接請求時候,才會實例化service。
四、Services as singletons
最后,我們必須意識到所有angular service都是一個單例應用。這意味著每一個injector中有且只有一個給定service的實例。由于angular是極其討厭破壞global state的,所以創(chuàng)建多個injector,使每一個都有指定service的實例是可行的,除了在測試中有強烈的需求外,一般很少有這樣的需要。
以上就是關(guān)于Angular Services 的資料整理,后續(xù)繼續(xù)補充相關(guān)資料,謝謝大家對本站的支持!
- AngularJS入門教程之服務(wù)(Service)
- angularJS Provider、factory、service詳解及實例代碼
- 簡介AngularJS中使用factory和service的方法
- 簡介AngularJS中$http服務(wù)的用法
- AngularJS中$http服務(wù)常用的應用及參數(shù)
- Angularjs 自定義服務(wù)的三種方式(推薦)
- AngularJs自定義服務(wù)之實現(xiàn)簽名和加密
- AngularJS 服務(wù)詳細講解及示例代碼
- AngularJS入門教程之REST和定制服務(wù)詳解
- AngularJS通過$http和服務(wù)器通信詳解
- AngularJS服務(wù)service用法總結(jié)
相關(guān)文章
angular4自定義表單控件[(ngModel)]的實現(xiàn)
這篇文章主要介紹了angular4自定義表單控件[(ngModel)]的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11Angular2使用SVG自定義圖表(條形圖、折線圖)組件示例
這篇文章主要介紹了Angular2使用SVG自定義圖表(條形圖、折線圖)組件,涉及Angular結(jié)合svg進行圖表繪制的相關(guān)操作技巧,需要的朋友可以參考下2019-05-05AngularJS基礎(chǔ) ng-keypress 指令簡單示例
本文主要介紹AngularJS ng-keypress 指令,這里對ng-keypress指令的基礎(chǔ)資料整理,并附有實例代碼,需要的小伙伴參考下2016-08-08