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
});

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

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...