专栏首页快乐八哥Angular Service入门

Angular Service入门

1.Angular内置service

Angular为了方便开发者开发,本身提供了非常多的内置服务。可以通过https://docs.angularjs.org/api/ng/service查看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

<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代码举例:

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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Angular定义服务-Learn By Doing

    1.服务(Service)介绍 Angular services are substitutable objects that are wired toget...

    八哥
  • Angular企业级开发(10)-Smart Table插件开发

    1.Smart Table内置的分页功能 Smart Table是基于AngularJS模块特性开发出来的一款优秀的表格组件,默认就支持过滤、排序等核心功能。开...

    八哥
  • 探索客户端JavaScript

    JavaScript在客户端和服务器的应用场景。 Draft and Typescript, Node.js 第一部分:JavaScript中的定时器 Java...

    八哥
  • 从用户行为去理解内容-item2vec及其应用

    从内容属性去理解用户行为,预测用户行为,那么也可以通过理解用户行为去理解内容,预测内容属性。

    腾讯知文实验室
  • CentOS6.5上配置Python2.7+OpenCV2.4.13

    版权声明:本文为博主原创文章,转载请注明源地址。 https://blog.csdn.net...

    用户1148648
  • 禁用浏览器右键菜单等操作

    薛定喵君
  • OpenCV丢失Nonfree模块(解决方案1)

    (关于解决方案2:https://blog.csdn.net/IT_flying625/article/details/103231212)

    种花家的奋斗兔
  • 恶狗变萌犬,路人妹子变老婆:日本开源GAN“插件”,想P哪里点哪里 | Demo

    想修哪里点哪里,这是东京大学和日本独角兽Preferred Networks开源的“插件”,可调教各种GAN:包括BigGAN和StyleGAN,也不用重新训练...

    量子位
  • 计算广告笔记07-数据加工与交易

    对浏览器行为,最常使用的用户标识是cookie,但由于存在同时使用多个浏览器、cookie过期或用户主动消除cookie的情况,这种用户标识的长期一致性不算太好...

    公众号-不为谁写的歌
  • 数据结构实验——校园导游 实现最小生成树+最短路

    (1)设计学校的校园平面图。选取若干个有代表性的景点抽象成一个无向带权图(无向网),以图中顶点表示校内各景点,边上的权值表示两景点之间的距离。

    glm233

扫码关注云+社区

领取腾讯云代金券