博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Angular Service入门
阅读量:6080 次
发布时间:2019-06-20

本文共 2666 字,大约阅读时间需要 8 分钟。

1.Angular内置service

Angular为了方便开发者开发,本身提供了非常多的内置服务。可以通过查看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

{
{books.summaryData.bookCount}} Books -- {
{books.summaryData.readerCount}} Readers -- {
{books.summaryData.grandTotalMinutes}} Total Minutes Read

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

项目地址:

参考网址

本文转自快乐八哥博客园博客,原文链接http://www.cnblogs.com/liminjun88/p/5652176.html如需转载请自行联系原作者
快乐八哥
你可能感兴趣的文章
系统架构简单图解
查看>>
浅谈加密技术
查看>>
centOS7下安装GUI图形界面
查看>>
一张图透析阿里云API应用创新大赛
查看>>
sql重复行求和
查看>>
Microsoft Dynamics CRM 2013 and 2011 Update Rollups and Service Packs
查看>>
transient的理解
查看>>
python中if __name__ == '__main__': 介绍
查看>>
HackRF实现无线门铃信号分析重放
查看>>
Windows源码安装PyTorch 0.4
查看>>
AI开发者福音!阿里云推出国内首个基于英伟达NGC的GPU优化容器
查看>>
CentOS6安装和配置rsync
查看>>
在真机里安装 ubuntu 14.04和一些常用的软件(二)
查看>>
python2.6升级到2.7
查看>>
Unity SLua 如何调用Unity中C#方法
查看>>
MyBatis排序时使用order by 动态参数时需要注意,用$而不是#
查看>>
linux基础命令-查看系统状态-free -m以及top命令详解
查看>>
动态代理
查看>>
批量删除redis key
查看>>
被嫌弃的eval和with
查看>>