返回介绍

广义回调管理

发布于 2024-12-24 22:41:42 字数 5915 浏览 0 评论 0 收藏 0

11.2. 广义回调管理

和其它框架一样, 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` 对象,以用于链式调用。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文