Angular为了方便开发者开发,本身提供了非常多的内置服务。可以通过https://docs.angularjs.org/api/ng/service查看AngularJS提供的内置服务。在企业级开发中,常用的服务有以下这些:
可以通过多种方式方式定义Service,常用的使用factory来定义一个service。代码如下:
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对象赋值。
定义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>
在实际开发过程中,我们需要对自己的服务进行增加一下方法,或者对引入的第三方服务增加一下方法,开发者可以不需要修改之前的源代码,而是可以在运行时为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