带有对象/原型的链式承诺(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));
我有一个简单的 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));