当前位置:  开发笔记 > 编程语言 > 正文

在运行时更改SetInterval的间隔

如何解决《在运行时更改SetInterval的间隔》经验,为你挑选了6个好方法。

我编写了一个javascript函数,它使用setInterval在十分之一秒内操作一个字符串,进行一定次数的迭代.

function timer() {
    var section = document.getElementById('txt').value;
    var len = section.length;
    var rands = new Array();

    for (i=0; i rands.max()) {
            clearInterval(interval);
        }
    }, 100);
};

我没有将间隔设置为特定的数字,而是希望在每次运行时根据计数器更新它.所以代替:

var interval = setInterval(function() { ... }, 100);

它会是这样的:

var interval = setInterval(function() { ... }, 10*counter);

不幸的是,这不起作用.似乎"10*counter"等于0.

那么,每次匿名函数运行时如何调整间隔?



1> nick..:

您可以使用匿名函数:

var counter = 10;
var myFunction = function(){
    clearInterval(interval);
    counter *= 10;
    interval = setInterval(myFunction, counter);
}
var interval = setInterval(myFunction, counter);

更新:根据A. Wolff的建议,使用setTimeout以避免需要clearInterval.

var counter = 10;
var myFunction = function() {
    counter *= 10;
    setTimeout(myFunction, counter);
}
setTimeout(myFunction, counter);


为什么使用间隔,简单的超时会更好,而无需清除它.例如:http://jsfiddle.net/fgs5nwgn/
好吧RozzA,我的答案于11月16日发布,用户28958于2013年8月22日发布,所以我将采取"代表"谢谢!
我坚持这个问题的背景.setTimeout当然会起作用

2> Peter Bailey..:

setTimeout()改用.然后回调将负责触发下一个超时,此时您可以增加或以其他方式操纵时序.

编辑

这是一个通用函数,可用于为任何函数调用应用"减速"超时.

function setDeceleratingTimeout(callback, factor, times)
{
    var internalCallback = function(tick, counter) {
        return function() {
            if (--tick >= 0) {
                window.setTimeout(internalCallback, ++counter * factor);
                callback();
            }
        }
    }(times, 0);

    window.setTimeout(internalCallback, factor);
};

// console.log() requires firebug    
setDeceleratingTimeout(function(){ console.log('hi'); }, 10, 10);
setDeceleratingTimeout(function(){ console.log('bye'); }, 100, 10);


在这里挑剔,但我得说,这段代码很难阅读.如果你要使用下一个支撑,至少要有正确的使用4-8空间缩进或永远不要超过2个缩进.IMO [此版本](http://pastebin.com/Y2yiG4FW)更容易阅读.还要注意将`t`重命名为`tick`,这是我最好的猜测,无论"t"应该代表什么.`t`是一个非常糟糕的变量名.
只给9 hi's :)` - t`应该是`t - `http://jsfiddle.net/albertjan/by5fd/

3> gnarf..:

我喜欢这个问题 - 在我身上启发了一个小计时器对象:

window.setVariableInterval = function(callbackFunc, timing) {
  var variableInterval = {
    interval: timing,
    callback: callbackFunc,
    stopped: false,
    runLoop: function() {
      if (variableInterval.stopped) return;
      var result = variableInterval.callback.call(variableInterval);
      if (typeof result == 'number')
      {
        if (result === 0) return;
        variableInterval.interval = result;
      }
      variableInterval.loop();
    },
    stop: function() {
      this.stopped = true;
      window.clearTimeout(this.timeout);
    },
    start: function() {
      this.stopped = false;
      return this.loop();
    },
    loop: function() {
      this.timeout = window.setTimeout(this.runLoop, this.interval);
      return this;
    }
  };

  return variableInterval.start();
};

使用示例

var vi = setVariableInterval(function() {
  // this is the variableInterval - so we can change/get the interval here:
  var interval = this.interval;

  // print it for the hell of it
  console.log(interval);

  // we can stop ourselves.
  if (interval>4000) this.stop();

  // we could return a new interval after doing something
  return interval + 100;
}, 100);  

// we can change the interval down here too
setTimeout(function() {
  vi.interval = 3500;
}, 1000);

// or tell it to start back up in a minute
setTimeout(function() {
  vi.interval = 100;
  vi.start();
}, 60000);


谢谢 - 让我走向正确的方向,为我正在做的事情做点什么.

4> 小智..:

我和原始海报有同样的问题,这是一个解决方案.不确定这是多么有效....

interval = 5000; // initial condition
var run = setInterval(request , interval); // start setInterval as "run"

    function request() { 

        console.log(interval); // firebug or chrome log
        clearInterval(run); // stop the setInterval()

         // dynamically change the run interval
        if(interval>200 ){
          interval = interval*.8;
        }else{
          interval = interval*1.2;
        }

        run = setInterval(request, interval); // start the setInterval()

    }


我99%肯定你对'setInterval`的说法是错误的@RozzA - 它仍然受到与任何其他JavaScript相同的延迟,并且几乎每个浏览器也将setInterval限制为4ms.你有关于这个或什么的帖子的链接?

5> 小智..:

一种更简单的方法是if在刷新的函数中使用一个语句,并以一个控制来定期执行命令.在以下示例中,我每2秒运行一次警报,并且intrv可以动态更改interval()...

var i=1;
var intrv=2; // << control this variable

var refreshId = setInterval(function() {
  if(!(i%intrv)) {
    alert('run!');
  }
  i++;
}, 1000);



6> Atticweb..:

这是我这样做的方式,我使用setTimeout:

var timer = {
    running: false,
    iv: 5000,
    timeout: false,
    cb : function(){},
    start : function(cb,iv){
        var elm = this;
        clearInterval(this.timeout);
        this.running = true;
        if(cb) this.cb = cb;
        if(iv) this.iv = iv;
        this.timeout = setTimeout(function(){elm.execute(elm)}, this.iv);
    },
    execute : function(e){
        if(!e.running) return false;
        e.cb();
        e.start();
    },
    stop : function(){
        this.running = false;
    },
    set_interval : function(iv){
        clearInterval(this.timeout);
        this.start(false, iv);
    }
};

用法:

timer.start(function(){
    console.debug('go');
}, 2000);

timer.set_interval(500);

timer.stop();

推荐阅读
罗文彬2502852027
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有