angular中的$q服务 实例

用于理解$q服务

参考:http://www.zouyesheng.com/angular.html#toc39

广义回调管理

和其它框架一样, ng 提供了广义的异步回调管理的机制。 $http 服务是在其之上封装出来的。这个机制就是 ng 的 $q 服务。

不过 ng 的这套机制总的来说实现得比较简单,按官方的说法,够用了。

使用的方法,基本上是:

  • 通过 $q 服务得到一个 deferred 实例
  • 通过 deferred 实例的 promise 属性得到一个 promise 对象
  • promise 对象负责定义回调函数
  • deferred 实例负责触发回调
var TestCtrl = function($q){
  var defer = $q.defer();
  var promise = defer.promise;
  promise.then(function(data){console.log(‘ok, ‘ + data)},
               function(data){console.log(‘error, ‘ + data)});
  //defer.reject(‘xx‘);
  defer.resolve(‘xx‘);
}

了解了上面的东西,再分别看 $q , deferred , promise 这三个东西。

11.2.1. $q

$q 有四个方法:

  • $q.all() 合并多个 promise ,得到一个新的 promise
  • $q.defer() 返回一个 deferred 对象
  • $q.reject() 包装一个错误,以使回调链能正确处理下去
  • $q.when() 返回一个 promise 对象

$q.all() 方法适用于并发场景很合适:

var TestCtrl = function($q, $http){
  var p = $http.get(‘/json‘, {params: {a: 1}});
  var p2 = $http.get(‘/json‘, {params: {a: 2}});
  var all = $q.all([p, p2]);
  p.success(function(res){console.log(‘here‘)});
  all.then(function(res){console.log(res[0])});
}

$q.reject() 方法是在你捕捉异常之后,又要把这个异常在回调链中传下去时使用:

要理解这东西,先看看 promise 的链式回调是如何运作的,看下面两段代码的区别:

var defer = $q.defer();
var p = defer.promise;
p.then(
  function(data){return ‘xxx‘}
);
p.then(
  function(data){console.log(data)}
);
defer.resolve(‘123‘);
var defer = $q.defer();
var p = defer.promise;
var p2 = p.then(
  function(data){return ‘xxx‘}
);
p2.then(
  function(data){console.log(data)}
);
defer.resolve(‘123‘);

从模型上看,前者是“并发”,后者才是“链式”。

而 $q.reject() 的作用就是触发后链的 error 回调:

var defer = $q.defer();
var p = defer.promise;
p.then(
  function(data){return data},
  function(data){return $q.reject(data)}
).
then(
  function(data){console.log(‘ok, ‘ + data)},
  function(data){console.log(‘error, ‘ + data)}
)
defer.reject(‘123‘);

最后的 $q.when() 是把数据封装成 promise 对象:

var p = $q.when(0, function(data){return data},
                   function(data){return data});
p.then(
  function(data){console.log(‘ok, ‘ + data)},
  function(data){console.log(‘error, ‘ + data)}
);

11.2.2. deferred

deferred 对象有两个方法一个属性。

  • promise 属性就是返回一个 promise 对象的。
  • resolve() 成功回调
  • reject() 失败回调
var defer = $q.defer();
var promise = defer.promise;
promise.then(function(data){console.log(‘ok, ‘ + data)},
             function(data){console.log(‘error, ‘ + data)});
//defer.reject(‘xx‘);
defer.resolve(‘xx‘);

11.2.3. promise

promise 对象只有 then() 一个方法,注册成功回调函数和失败回调函数,再返回一个promise 对象,以用于链式调用。

下面是自己写的例子

  var MyApp = angular.module(‘MyApp‘,[]);

  MyApp.controller(‘ListCtrl‘, [‘$scope‘,‘$http‘, ‘$q‘, function($scope, $http ,$q){
    $scope.name = ‘hello‘;

    function demo(){
      var deferred = $q.defer();
      // 简写版本
      $http.get(‘data.json‘)
      .success(function(data,status,headers){
        deferred.resolve(data);
      })
      .error(function(data){
        var reason = data;
        deferred.reject(reason);
      })

      return deferred.promise;
    }

    //触发premise的success
    demo().then(function(data){
      $scope.list = data;
    })

  }])

demo

时间: 2024-08-03 17:58:29

angular中的$q服务 实例的相关文章

形象的讲解angular中的$q与promise(转)

以下内容摘自http://www.ngnice.com/posts/126ee9cf6ddb68 promise不是angular首创的,作为一种编程模式,它出现在……1976年,比js还要古老得多.promise全称是 Futures and promises.具体的可以参见 http://en.wikipedia.org/wiki/Futures_and_promises . 而在javascript世界中,一个广泛流行的库叫做Q 地址是https://github.com/kriskowa

promise和Angular中的 $q, defer

在ES6语法中,新出了promise构造函数, 可用来生成promise实例. Promise对象: 代表了未来某个将要发生的事件(通常是一个异步操作).有了promise对象, 可以将异步操作以同步的流程表达出来, 避免了层层嵌套的回调函数(俗称'回调地狱'). 在Angularjs中,对象deferred 实例也可以暴露派生的Promise 实例.以下将对此作简单描述: 1. $q: $q是Angular的一种内置服务,它可以使你异步地执行函数,并且当函数执行完成时它允许你使用函数的返回值(

Angular中的$q的形象解释及深入用法

作者:寸志链接:https://zhuanlan.zhihu.com/p/19622332来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 早上,老爸说:"儿子,天气如何?" 每周一早上,老爸问儿子下午的天气情况,儿子可以到自家房子旁边小山上使用望远镜来观看.儿子在出发时许诺(Promise)老爸(会通知老爸天气情况). 此刻,老爸决定,如果天气不错,明天就出去捕鱼,否则就不去.而且如果儿子无法获得天气预报的话,也不去捕鱼. 30分钟左右,儿子回来了,每周

angular中的$q详解

先说说什么是Promise,什么是$q吧.Promise是一种异步处理模式,有很多的实现方式,比如著名的Kris Kwal's Q还有JQuery的Deffered. 什么是Promise 以前了解过Ajax的都能体会到回调的痛苦,同步的代码很容易调试,但是异步回调的代码,会让开发者陷入泥潭,无法跟踪,比如: funA(arg1,arg2,function(){ funcB(arg1,arg2,function(){ funcC(arg1,arg2,function(){ xxxx.... })

高效利用Angular中内置服务

AngularJS中为我们提供了众多的内置服务,通过这些内置服务可以轻松的实现一些常用功能.下面对Angular中常用的内置服务进行一下总结. 1.$location服务 $location服务用于返回当前页面的URL地址,示例代码如下: var app = angular.module('myApp', []); app.controller('customersCtrl', function($scope, $location) { $scope.myUrl = $location.absU

angular中 通过$q 异步方式 获取服务数据

//服务中 获取check列表 services.factory('checkservice', ['$http','$q',     function($http,$q) {       return {          checks : function(groupName){          var deferred1 = $q.defer()          $http.get("/checksJsonByGroup2?groupName="+groupName)    

angular中的$http服务

$http是ng内置的一个服务.是简单的封装了浏览器原生的XMLHttpRequest对象. 写法1 $http({ method: "GET", url: 'data.json', }).success(function(data, status, headers, config){ $scope.list = data; }).error(function(data, status, headers, config) { // }); 实际上$http方法返回一个promise对象

angular中的$http服务,对应的参数

method:http请求方式,可以为GET,DELETE,HEAD,JSONP,POST,PUT url:字符串,请求的url地址 params:字符串或者对象,会被转换成为查询字符串追加的url后面 data:在发送post请求时使用,作为消息体发送到服务器 headers:一个列表,每个元素都是一个函数,返回http头 xsrfHeaderName(字符串):保存XSFR令牌的http头的名称 xsrfCookieName:保存XSFR令牌的cookie名称 transformReques

$q 实例分析 Angular 中的 Promise

相信有一些开发经验的朋友就应该知道,对于JavaScript而言,promise十分重要,在开发中总能用到.因此掌握好它是一件必须做的事情. 我之前写过一篇文章,工作总结:jQuery高级应用之Deferred对象,介绍jquery中的promise,因此关于promise的基础介绍就不再详细讲解,这篇文章会重点关注angular中promise的实现. 我们首先有一个简单的html标签,下面的例子都会基于这个标签来书写 <div ng-app="app" ng-controll