带有对象/原型的链式承诺(Q deferred)

Chained Promises (Q deferred) with Object / Prototype

我有一个简单的 Javascript(节点)对象,它有一个在对象上设置 属性 和 returns 承诺的函数。

请注意,对于此示例,我删除了需要延迟的实际异步调用,因为它不会影响结果。

var q = require("Q");

var Foo = function(){
  this.bar = false;
  return this;
};

Foo.prototype.set = function(){
  var d = q.defer();
  this.bar = true; 
  d.resolve();
  return d.promise;
};

Foo.prototype.check = function(){
  var d = q.defer();
  console.log(this.bar);
  d.resolve();
  return d.promise;
};

当以如下所示的破坏承诺的方式调用上面的代码时,this.bar 为真(如预期的那样)。

var foo = new Foo();
foo.set().then(function(){
  foo.check();
});

但是,在链中调用时,它是未定义的:

foo.set().then(foo.check);

我很想知道是什么原因造成的。我最好的猜测是我的对象的方法链接在一起的方式存在闭包问题。

在大多数情况下,我会将值传递给 resolve/reject 并从那里开始。在这种情况下,我想通过一系列顺序函数(有些需要延迟)来 运行 一些数据。我不想将输出传递给链中的每个函数,而是希望在对象本身中存储和更新数据。

任何清晰度将不胜感激!

你在没有上下文的情况下调用回调的问题 this 只是全局对象

作为解决方案,您需要像这样绑定上下文

foo.set().then(foo.check.bind(foo));