Angular Service入門

1.Angular內置service

Angular爲了方便開發者開發,自己提供了很是多的內置服務。能夠經過https://docs.angularjs.org/api/ng/service查看AngularJS提供的內置服務。在企業級開發中,經常使用的服務有如下這些:html

  • $cacheFactory 緩存服務
  • $compile 編譯服務
  • $filter 經過 $filter 服務能夠格式化輸出數據,也能夠對數據進行過濾操做
  • $http AngularJS內置的核心的服務,主要和後臺請求相關
  • $location 基於window.location的Angular版本,功能更強大。好比路由地址的切換: $location.path('/home')
  • $log 開發過程當中用到的多,輸入錯誤和調試日誌。和Chrome瀏覽器的console.log()、console.debug()等相似
  • $q 服務主要是用於異步函數返回一個promise,在路由中resovle屬性用的較多
  • $rootScope 一個應用只有一個 $rootScope,該服務能夠用於每一個頁面都須要使用的公共數據或者變量,可是開發過程當中,建議儘可能少用 $rootScope,調試起來不方便。由於它是一個全局變量。

2.Angular自定義Service

能夠經過多種方式方式定義Service,經常使用的使用factory來定義一個service。代碼以下:git

app.factory('dataService', function () {
    var appVerison = "1.0";
    var showVersion = function () {
        return appVerison;
    };

    return {
        appTitle: "Decorators Demo",
        showVersion: showVersion
    }
});

3.在控制器之間共享數據使用Service

控制器和控制器之間共享數據也有多種方式,將變量或者函數綁定$rootScope是一種常見的方式,可是不推薦。常見的狀況是使用Service來共享多個controller之間的數據。一個記錄圖書閱讀的系統,須要記錄最後一次編輯的圖書信息。
BooksController.js裏面讀取currentUser服務,在編輯的頁面給currentUser服務裏面的lastBookEdited對象賦值。angularjs

定義currentUser服務github

angular.module('app')
    .factory('currentUser', function () {
        var lastBookEdited = {};
        return {
            lastBookEdited: lastBookEdited
        }
        
    });

在EditController.js設計模式

dataService.getBookByID($routeParams.bookId)
            .then(function (response) {
                vm.currentBook = response;
//將當前編輯的圖書對象賦值給lastBookEdited
                currentUser.lastBookEdited=vm.currentBook;屬性
            })
            .catch(function (response) {
                $log.error(response);
            });

BooksController.jsapi

vm.currentUser=currentUser;

模板books.htmlpromise

<div>
    {{books.summaryData.bookCount}} Books --
    {{books.summaryData.readerCount}} Readers --

    {{books.summaryData.grandTotalMinutes}} Total Minutes Read
</div>

4.Decorators(修飾)在Angular Service的使用

在實際開發過程當中,咱們須要對本身的服務進行增長一下方法,或者對引入的第三方服務增長一下方法,開發者能夠不須要修改以前的源代碼,而是能夠在運行時爲Service增長方法。這裏須要用到Decorator-修飾。修飾模式是軟件設計裏面一種經典設計模式,在高級的面嚮對象語言,好比Java、C#等都有實現。AngularJS代碼舉例:瀏覽器

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緩存

參考網址app

相關文章
相關標籤/搜索