javascript – 在触发两个事件时运行代码

前端之家收集整理的这篇文章主要介绍了javascript – 在触发两个事件时运行代码前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
这主要是与语言无关的问题.

如果我正在等待两个事件完成(例如,两个IO事件或http请求),那么处理这个问题的最佳模式是什么.我能想到的一件事是以下(伪js例子).

request1.onComplete = function() {
  req1Completed = true;
  eventsCompleted();
}

request2.onComplete = function() {
  req2Completed = true;
  eventsCompleted();
}

eventsCompleted = function() {

  if (!req1Completed || !req2Completed) return;
  // do stuff

}

这是最有效的模式,还是有更优雅的方法解决这个问题?

解决方法

在进入细节之前,这里有一些利用我头脑中的lambda函数的整洁:
function makeCountdownCallback(count,callback) {
    return function() {
        if (--count == 0)
            callback();
    };
}

request1.onComplete = request2.onComplete = makeCountdownCallback(2,function() {
    // do stuff
});

这显然假设每个事件最多触发一次,并且不利用顺序.

猜你在找的JavaScript相关文章