Angular Service入门

1.Angular内置service

Angular为了方便开发者开发,自己提供了很是多的内置服务。能够经过https://docs.angularjs.org/api/ng/service查看AngularJS提供的内置服务。在企业级开发中,经常使用的服务有如下这些:javascript

  • $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。代码以下:php

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对象赋值。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>

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

在实际开发过程当中,咱们须要对本身的服务进行增长一下方法,或者对引入的第三方服务增长一下方法,开发者能够不须要修改以前的源代码,而是能够在运行时为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