关于setTimeout和setInterval

1、setTimeout定时器

setTimeout(code,millisec)

setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式。
注:调用过程中,可以使用clearTimeout(id_of_settimeout)终止

  • code 必需,要调用的函数后要执行的 JavaScript 代码串。
  • millisec 必需,在执行代码前需等待的毫秒数。

例子1:

 for(var i=1;i<=5;i++){
 setTimeout( function timer() {
       console.log(i);
     }, i*1000 );
 }

输出:

427(唯一ID) 
6 
6 
6 
6 
6 

页面中所有由setTimeout定义的操作,都将放在同一个队列中依次执行,队列的特点是:先进先出。而这个队列执行的时间,需要等待到函数调用栈清空之后才开始执行。即所有可执行代码执行完毕之后,才会开始执行由setTimeout定义的操作。而这些操作进入队列的顺序,则由设定的延迟时间来决定。

对于例子2:

 var timer = setTimeout(function() {
     console.log('setTimeout actions.');
}, 0);
console.log('other actions.');

输出:

other actions. 
setTimeout actions。

上面这个例子中,即使我们将延迟时间设置为0,它定义的操作仍然需要等待所有代码执行完毕之后才开始执行。这里的延迟时间,并非相对于setTimeout执行这一刻,而是相对于其他代码执行完毕这一刻。

对于例子1,如果我们直接这样写,根据setTimeout定义的操作在函数调用栈清空之后才会执行的特点,for循环里定义了5个setTimeout操作。而当这些操作开始执行时,for循环的i值,已经先一步变成了6。因此输出结果总为6。而我们想要让输出结果依次执行,我们就必须借助闭包的特性,每次循环时,将i值保存在一个闭包中,当setTimeout中定义的操作执行时,则访问对应闭包保存的i值即可。

将例子1代码改为:
我们只需要2个操作就可以完成题目需求,一是使用自执行函数提供闭包条件,二是传入i值并保存在闭包中

for (var i=1; i<=5; i++) { 

    (function(i) {
        setTimeout( function timer() {
            console.log(i);
        }, i*1000 );
    })(i)
}

或者在setTimeout函数的第一个参数处使用闭包

for (var i=1; i<=5; i++) { 
    setTimeout( (function(i) {
        return function() {
            console.log(i);
        }
    })(i), i*1000 );
}

此时的执行结果为:

1
2
3
4
5

2、setInterval定时器

使用方法:

setInterval(code,millisec[,"lang"])

  • code:执行的代码段
  • millisec:周期性执行或调用 code 之间的时间间隔,以毫秒计。

3、setTimeout和setInterval 区别

  • setTimeout只执行一次那段代码
  • setInterval在执行完一次代码之后,经过了那个固定的时间间隔,它还会自动重复执行代码

即setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式,而setInterval()则可以在每隔指定的毫秒数循环调用函数或表达式,直到clearInterval把它清除。

你可能感兴趣的:(关于setTimeout和setInterval)