AngularService入門-創(chuàng)新互聯(lián)

1.Angular內(nèi)置service

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

創(chuàng)新互聯(lián)建站堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的三明網(wǎng)站設(shè)計(jì)、移動媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
  • $cacheFactory 緩存服務(wù)

  • $compile 編譯服務(wù)

  • $filter 通過 $filter 服務(wù)可以格式化輸出數(shù)據(jù),也可以對數(shù)據(jù)進(jìn)行過濾操作

  • $http AngularJS內(nèi)置的核心的服務(wù),主要和后臺請求相關(guān)

  • $location 基于window.location的Angular版本,功能更強(qiáng)大。比如路由地址的切換: $location.path('/home')

  • $log 開發(fā)過程中用到的多,輸入錯誤和調(diào)試日志。和Chrome瀏覽器的console.log()、console.debug()等類似

  • $q 服務(wù)主要是用于異步函數(shù)返回一個promise,在路由中resovle屬性用的較多

  • $rootScope 一個應(yīng)用只有一個 $rootScope,該服務(wù)可以用于每個頁面都需要使用的公共數(shù)據(jù)或者變量,但是開發(fā)過程中,建議盡量少用 $rootScope,調(diào)試起來不方便。因?yàn)樗且粋€全局變量。

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.在控制器之間共享數(shù)據(jù)使用Service

控制器和控制器之間共享數(shù)據(jù)也有多種方式,將變量或者函數(shù)綁定$rootScope是一種常見的方式,但是不推薦。常見的情況是使用Service來共享多個controller之間的數(shù)據(jù)。一個記錄圖書閱讀的系統(tǒng),需要記錄最后一次編輯的圖書信息。
BooksController.js里面讀取currentUser服務(wù),在編輯的頁面給currentUser服務(wù)里面的lastBookEdited對象賦值。

定義currentUser服務(wù)

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

在EditController.js

dataService.getBookByID($routeParams.bookId)
            .then(function (response) {
                vm.currentBook = response;//將當(dāng)前編輯的圖書對象賦值給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的使用

在實(shí)際開發(fā)過程中,我們需要對自己的服務(wù)進(jìn)行增加一下方法,或者對引入的第三方服務(wù)增加一下方法,開發(fā)者可以不需要修改之前的源代碼,而是可以在運(yùn)行時為Service增加方法。這里需要用到Decorator-修飾。修飾模式是軟件設(shè)計(jì)里面一種經(jīng)典設(shè)計(jì)模式,在高級的面向?qū)ο笳Z言,比如Java、C#等都有實(shí)現(xiàn)。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;
    });
});

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

名稱欄目:AngularService入門-創(chuàng)新互聯(lián)
文章鏈接:http://muchs.cn/article2/ddhjoc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版用戶體驗(yàn)、電子商務(wù)網(wǎng)站制作搜索引擎優(yōu)化、品牌網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)