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;
    });
});
本文转自帅气的头头博客51CTO博客,原文链接http://blog.51cto.com/12902932/1926235如需转载请自行联系原作者

sshpp
相关文章
|
JavaScript 前端开发
实战之AngularJS 的Scope和Service的深入应用心得
实战之AngularJS 的Scope和Service的深入应用心得
实战之AngularJS 的Scope和Service的深入应用心得
|
JavaScript
Angular入门,开发环境搭建,使用Angular CLI创建你的第一个Angular项目
Angular入门,开发环境搭建,使用Angular CLI创建你的第一个Angular项目
425 0
Angular入门,开发环境搭建,使用Angular CLI创建你的第一个Angular项目
|
Java C#
angularJS学习小结——service
angularJS学习小结——service
102 0
|
缓存
Angular CLI找不到模块"angular-devkit/build-angular"
Angular CLI 是 Angular 客户端命令行工具,提供非常多的命令来简化 Angular 的开发。今天执行“ng serve”命令时,竟然报找不到模块"@angular-devkit/build-angular"的错误。
2409 0
|
前端开发 JavaScript API
第220天:Angular---路由
内容介绍,为什么要使用前端路由? 在2005左右,兴起了一种叫做ajax的技术,有了ajax之后,我们向服务端提交数据的时候就不再需要使用from表单去提交了,因为from表单之间的提交会导致页面之间的切换,也就是说无法实现单页应用。
1362 0
|
Java .NET 开发框架
使用Angular CLI生成路由
第一篇文章是: "使用angular cli生成angular5项目" : http://www.cnblogs.com/cgzl/p/8594571.html 第二篇文章是: "使用angular cli从蓝本生成代码" : http://www.
928 0
|
Java .NET 开发框架
使用Angular CLI从蓝本生成代码
第一篇文章是: "使用angular cli生成angular5项目" : http://www.cnblogs.com/cgzl/p/8594571.html 这篇文章主要是讲生成 Components, Directive, Service, class, interface, enum等等.
1312 0
|
开发工具 前端开发 git
使用Angular CLI生成 Angular 5项目
如果您正在使用angular, 但是没有好好利用angular cli的话, 那么可以看看本文. Angular CLI 官网: https://github.com/angular/angular-cli 安装angular cli: npm install -g @angular/cli   不过首先要确保您安装了比较新版本的nodejs.
1225 0
|
前端开发
angular-cli 使用 bootstrap_angular 4.0 怎样使用 bootstrap
转载自  http://www.ngui.cc/index.html angular 使用bootstrap ngx-bootstrap  文档地址  http://ngx-bootstrap.
1057 0