首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >更改SetInterval运行时的时间间隔

更改SetInterval运行时的时间间隔
EN

Stack Overflow用户
提问于 2009-08-15 05:14:03
回答 12查看 175.3K关注 0票数 177

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

代码语言:javascript
复制
function timer() {
    var section = document.getElementById('txt').value;
    var len = section.length;
    var rands = new Array();

    for (i=0; i<len; i++) {
        rands.push(Math.floor(Math.random()*len));
    };

    var counter = 0
    var interval = setInterval(function() {
        var letters = section.split('');
        for (j=0; j < len; j++) {
            if (counter < rands[j]) {
                letters[j] = Math.floor(Math.random()*9);
            };
        };
        document.getElementById('txt').value = letters.join('');
        counter++

        if (counter > rands.max()) {
            clearInterval(interval);
        }
    }, 100);
};

我希望在每次运行时根据计数器更新它,而不是将间隔设置为一个特定的数字。因此,不是:

代码语言:javascript
复制
var interval = setInterval(function() { ... }, 100);

它应该是这样的:

代码语言:javascript
复制
var interval = setInterval(function() { ... }, 10*counter);

不幸的是,这并不管用。看起来“10*计数器”等于0。

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

EN

回答 12

Stack Overflow用户

回答已采纳

发布于 2009-08-14 21:18:01

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

编辑

下面是一个泛型函数,您可以使用它为任何函数调用应用“减速”超时。

代码语言:javascript
复制
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);
票数 123
EN

Stack Overflow用户

发布于 2011-09-16 22:01:04

您可以使用匿名函数:

代码语言:javascript
复制
var counter = 10;
var myFunction = function(){
    clearInterval(interval);
    counter *= 10;
    interval = setInterval(myFunction, counter);
}
var interval = setInterval(myFunction, counter);

更新:正如A.Wolff所建议的,使用setTimeout来避免对clearInterval的需要。

代码语言:javascript
复制
var counter = 10;
var myFunction = function() {
    counter *= 10;
    setTimeout(myFunction, counter);
}
setTimeout(myFunction, counter);
票数 139
EN

Stack Overflow用户

发布于 2009-08-14 22:24:42

我喜欢这个受问题启发的小计时器对象:

代码语言:javascript
复制
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();
};

示例用法

代码语言:javascript
复制
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);
票数 24
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1280263

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档