91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Angular Service入門

發布時間:2020-07-09 14:10:08 來源:網絡 閱讀:393 作者:sshpp 欄目:網絡安全
1.Angular內置service

Angular為了方便開發者開發,本身提供了非常多的內置服務。可以通過https://docs.angularjs.org/api/ng/service查看AngularJS提供的內置服務。在企業級開發中,常用的服務有以下這些:

  • $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。代碼如下:

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對象賦值。

定義currentUser服務

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.js

vm.currentUser=currentUser;

模板books.html

<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;
    });
});


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

运城市| 徐汇区| 中宁县| 海淀区| 天镇县| 宁化县| 苍梧县| 云阳县| 清水县| 米泉市| 顺平县| 科技| 藁城市| 肃南| 阿尔山市| 亳州市| 佳木斯市| 轮台县| 郎溪县| 六枝特区| 肇东市| 文昌市| 延吉市| 宣武区| 黄山市| 长宁县| 和顺县| 启东市| 金平| 德钦县| 井陉县| 凉山| 旬邑县| 雷波县| 德令哈市| 安西县| 平利县| 溆浦县| 将乐县| 梅河口市| 乌鲁木齐县|