Angular Service入门
1.Angular内置serviceAngular为了方便开发者开发,本身提供了非常多的内置服务。可以通过https://docs.angularjs.org/api/ng/service查看AngularJS提供的内置服务。在企业级开发中,常用的服务有以下这些:
2.Angular自定义Service可以通过多种方式方式定义Service,常用的使用factory来定义一个service。代码如下: app.factory('dataService',function(){varappVerison="1.0";varshowVersion=function(){returnappVerison; };return{ appTitle:"DecoratorsDemo",showVersion:showVersion } }); 3.在控制器之间共享数据使用Service控制器和控制器之间共享数据也有多种方式,将变量或者函数绑定$rootScope是一种常见的方式,但是不推荐。常见的情况是使用Service来共享多个controller之间的数据。一个记录图书阅读的系统,需要记录最后一次编辑的图书信息。 定义currentUser服务 angular.module('app') .factory('currentUser',function(){varlastBookEdited={};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}}TotalMinutesRead</div> 4.Decorators(修饰)在Angular Service的使用在实际开发过程中,我们需要对自己的服务进行增加一下方法,或者对引入的第三方服务增加一下方法,开发者可以不需要修改之前的源代码,而是可以在运行时为Service增加方法。这里需要用到Decorator-修饰。修饰模式是软件设计里面一种经典设计模式,在高级的面向对象语言,比如Java、C#等都有实现。AngularJS代码举例: varapp=angular.module('app',[]); app.controller('MainCtrl',function($scope,dataService){ $scope.app=dataService; }); app.factory('dataService',showVersion:showVersion } }); app.config(function($provide){ $provide.decorator('dataService',function($delegate){ $delegate.sayHello=function(){return"anewfunctionof'dataService'"; };return$delegate; }); }); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |