Angular爲了方便開發者開發,自己提供了很是多的內置服務。能夠經過https://docs.angularjs.org/api/ng/service查看AngularJS提供的內置服務。在企業級開發中,經常使用的服務有如下這些:javascript
能夠經過多種方式方式定義Service,經常使用的使用factory來定義一個service。代碼以下:php
app.factory('dataService', function () { var appVerison = "1.0"; var showVersion = function () { return appVerison; }; return { appTitle: "Decorators Demo", showVersion: showVersion } });
控制器和控制器之間共享數據也有多種方式,將變量或者函數綁定$rootScope是一種常見的方式,可是不推薦。常見的狀況是使用Service來共享多個controller之間的數據。一個記錄圖書閱讀的系統,須要記錄最後一次編輯的圖書信息。
在BooksController.js
裏面讀取currentUser服務,在編輯的頁面給currentUser服務裏面的lastBookEdited對象賦值。html
定義currentUser服務java
angular.module('app') .factory('currentUser', function () { var lastBookEdited = {}; return { lastBookEdited: lastBookEdited } });
在EditController.jsgit
dataService.getBookByID($routeParams.bookId)
.then(function (response) { vm.currentBook = response; //將當前編輯的圖書對象賦值給lastBookEdited currentUser.lastBookEdited=vm.currentBook;屬性 }) .catch(function (response) { $log.error(response); });
BooksController.jsangularjs
vm.currentUser=currentUser;
模板books.htmlgithub
<div> {{books.summaryData.bookCount}} Books -- {{books.summaryData.readerCount}} Readers -- {{books.summaryData.grandTotalMinutes}} Total Minutes Read </div>
在實際開發過程當中,咱們須要對本身的服務進行增長一下方法,或者對引入的第三方服務增長一下方法,開發者能夠不須要修改以前的源代碼,而是能夠在運行時爲Service增長方法。這裏須要用到Decorator-修飾。修飾模式是軟件設計裏面一種經典設計模式,在高級的面嚮對象語言,好比Java、C#等都有實現。AngularJS代碼舉例:django
var app = angular.module('app', []); app.controller('MainCtrl', function ($scope, dataService) { $scope.app = dataService; }); app.factory('dataService', function () { var appVerison = "1.0"; var showVersion = function () { return appVerison; }; return { appTitle: "Decorators Demo", showVersion: showVersion } }); app.config(function ($provide) { $provide.decorator('dataService', function ($delegate) { $delegate.sayHello = function () { return "a new function of 'dataService'"; }; return $delegate; }); });
項目地址:https://github.com/cmssfe/angular-js-path/tree/master/angularjs-services-in-depth/BookLogger設計模式
參考網址api