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

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

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

  1. request1.onComplete = function() {
  2. req1Completed = true;
  3. eventsCompleted();
  4. }
  5.  
  6. request2.onComplete = function() {
  7. req2Completed = true;
  8. eventsCompleted();
  9. }
  10.  
  11. eventsCompleted = function() {
  12.  
  13. if (!req1Completed || !req2Completed) return;
  14. // do stuff
  15.  
  16. }

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

解决方法

在进入细节之前,这里有一些利用我头脑中的lambda函数的整洁:
  1. function makeCountdownCallback(count,callback) {
  2. return function() {
  3. if (--count == 0)
  4. callback();
  5. };
  6. }
  7.  
  8. request1.onComplete = request2.onComplete = makeCountdownCallback(2,function() {
  9. // do stuff
  10. });

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

猜你在找的JavaScript相关文章