queue.js如何工作?

时间:2012-12-23 05:31:29

标签: javascript asynchronous queue

我一直在努力了解Mike Bostock's queue.js的工作原理,但我看不出它是如何运作的。我不明白的部分是代码如何设法继续执行回调。特别是,我不确定pop()方法(第45行)。根据我的理解,该方法采用下一个未处理的延迟函数;附加一个回调(可能)启动队列中的下一个延迟函数,并在立即弹出的函数完成时执行;然后最后执行所述功能。我的问题是:什么代码执行此回调?

2 个答案:

答案 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()执行。