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);
  });

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...