我一直在努力了解Mike Bostock's queue.js的工作原理,但我看不出它是如何运作的。我不明白的部分是代码如何设法继续执行回调。特别是,我不确定pop()
方法(第45行)。根据我的理解,该方法采用下一个未处理的延迟函数;附加一个回调(可能)启动队列中的下一个延迟函数,并在立即弹出的函数完成时执行;然后最后执行所述功能。我的问题是:什么代码执行此回调?
答案 0 :(得分:10)
每个延迟函数实际上都不会返回任何内容 - 它们应该作为回调执行它们的最终参数。例如,这不起作用
var foo = function(i) {
console.log(i);
return i;
}
var finished = function(error, results) {
console.log(results);
}
queue(2)
.defer(foo, 1)
.defer(foo, 2)
.defer(foo, 3)
.defer(foo, 4)
.awaitAll(finished); // only prints "1" and "2", since foo() doesn't execute callbacks
但是,如果我们修改foo
以进行回调,
var foo = function(i, callback) {
console.log(i);
callback(null, i); // first argument is error reason, second is result
}
然后它将执行回调导致queue
继续。
答案 1 :(得分:2)
如果我正确理解了代码,queue.await()
和queue.awaitall()
将回调放在await
实例变量中,然后由notify()
执行。