微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – AngularJS:将其他参数传递给链式承诺

我想链接一些由服务返回的promise.只要一些返回promise的方法不需要额外的参数,这就可以工作.这是我的例子:
var first = function() {
  var d = $q.defer();
  $timeout(function() {
    d.resolve("first resolved")
  },100)
  return d.promise;
};

var second = function(val) {
  console.log("value of val: ",val);
  var d = $q.defer();
  $timeout(function() {
    d.resolve("second resolved")
  },200)
  return d.promise;
};

first().then(second).then(function(value) {
  console.log("all resolved",value);
});

这按预期工作.但是,如果我的服务第二个需要额外的参数val来完成它的工作怎么办?使用上面的方法,val的值是“首先解析”,因为它从第一个得到解析的值.

有没有办法,没有嵌套这样的匿名函数

first().then(function() {
  return second("foobar").then(function(value) {
    console.log("all resolved",value);
  });
});

我在考虑使用$q.all,但恕我直言,你不能指定你的承诺订单.

解决方法

当然.第一种方式:
first()
  .then(function() {
    return second("foobar");
  })
  .then(function(value) {
    console.log("all resolved",value);
  });

第二种(更容易)方式:

first()
  .then(second.bind(null,"foobar"))
  .then(function(value) {
    console.log("all resolved",value);
  });

原文地址:https://www.jb51.cc/js/158901.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐