【发布时间】:2015-02-09 11:23:45
【问题描述】:
我真的希望我在做一些愚蠢的事情,但我似乎找不到它。
我正在尝试在一系列承诺中使用 Ember.RSVP.all。我的例子比我的使用简单得多,但它说明了这个问题。在一系列 Promise 的中间,我有一组 Promise 需要在链可以继续之前解决 - 这正是我理解 RSVP.all 的目的。
不幸的是,当我返回 RSVP.all 对象时,链中的下一个 Promise 会立即运行,而无需等待传递给 all() 的 Promise。
我设置了一个 js fiddle 来以我能想到的最佳方式进行演示: http://jsfiddle.net/3a9arbht/3/
请注意,First 和 Second 几乎同时解析,此时 Second 应该在 1s 承诺返回之后。第三和第四如预期的那样。
小提琴代码如下:
function delayAjax(delay) {
return Ember.$.ajax({
url: '/echo/json/',
data: {
json: '',
delay: delay,
}
});
}
delayAjax(1).then(function() {
Ember.$('#first').addClass('red');
var proms = [delayAjax(1), delayAjax(1)];
return Ember.RSVP.all(proms)
}).then(function() {
Ember.$('#second').addClass('red');
return delayAjax(1);
}).then(function() {
Ember.$('#third').addClass('red');
return delayAjax(1);
}).then(function() {
Ember.$('#fourth').addClass('red');
});
【问题讨论】:
-
小提琴链接打错了吗?
-
啊,你说得对。对不起。更新到正确的链接:jsfiddle.net/3a9arbht/3
标签: javascript ember.js rsvp.js