延迟到方法链中的下一个函数

IT技术 javascript delay method-chaining
2021-03-13 05:33:29

我正在尝试了解有关 Javascript 中方法链的更多信息,并想知道在没有 jQuery 的情况下为链中的下一个函数创建延迟的正确方法:

var foo = function() {
    this.delay = function(per) {
        setTimeout(start, per);
        return this;
    };
    this.start = function() {
        alert('start!');
    };
};

var bar = new foo().delay(1000).start();
2个回答

这并不容易做到。jQuery 使用特定的队列系统

假设您想在没有 jQuery 的情况下执行此操作,则必须自己实现一个队列。

例如这个非常简单的实现:

var foo = function() {
    var queue = [];
    var timer;
    this.delay = function(per) {
      timer = setTimeout(function(){
        timer = 0;
        var f;
        while (f = queue.shift()) f();
      }, per);
      return this;
    };
    this.addFunction = function(f) {
      if (timer) queue.push(f);
      else f();
      return this;
    };
    this.start = function() {
       this.addFunction(function(){alert('start')});
       return this;
    };
};

示范


如果你想链接另一个没有在 foo 中定义的函数,你可以这样做

var bar = new foo().delay(3000).start()
    .addFunction(function(){alert("another chained one")});

示范

@user1982408 我编辑了一个更强大的队列和一个链接任意函数的例子。请注意,这仍然很简单,并不旨在为所有用途替换 jQuery 的队列;)
2021-04-27 05:33:29
一开始让我难以置信,但我开始理解其中的逻辑 - 真的谢谢你
2021-05-18 05:33:29

这将允许您链接多个延迟:http : //jsfiddle.net/z4Uyf/1/

js:

var foo = function() {

  var delayed = [];
  var delayExecution = false;
  var delayCount = 0;   
  function handleDelay(func){
    delayed.push(func);
    delayCount++;
  }

   function delayDone(){
     delayExecution = false;
     if( typeof(delayed[0]) == "function" ){
       delayed[0]();
       delayed.splice(0,1);
     }
     if( delayed.length > 0 ) delayExecution = true;
   }

   this.delay = function(per) {
        delayExecution = true;
        setTimeout(function(){
          delayDone();
        }, per);
        return this;
   };

  this.start = function() {
    if( delayExecution ){
     handleDelay(arguments.callee);
    }else{
     alert("start!");
    }
    return this;
  };
};

var bar = new foo().delay(1000).start().delay(5000).start();