计时器

作者: Lucien_d70a | 来源:发表于2017-10-12 23:54 被阅读0次

setTimeout("函数/代码",毫秒数,函数传递的参数) 只会执行一次

var time=setTimeout(function(){
  console.log(123)
},3000)

function fn(a,b){}
var time=setTimeout(fn,3000,2,3)

setInterval("函数/代码",毫秒数,函数传递的参数) 执行多次

var time=setInterval(function(){
  console.log(123)
},3000)

function fn(a,b){}
var time=setInterval(fn,3000,2,3)

一些过于计时器的面试题目

for(var i=0;i<5;i++){
        setTimeout(function(){
            console.log(i)
        },i*1000)
    }
    //0秒打出5,1秒打出5,2秒打出5,3秒打出5,4秒打出5,
for(var i=0;i<5;i++){
        (function(i){
            setTimeout(function(){
                console.log(i)
            },i*1000)
        })(i)
    }
    //0秒打出0,1秒打出1,2秒打出2,3秒打出3,4秒打出4,
for(var i=0;i<5;i++){
        (function(){
            setTimeout(function(){
                console.log(i)
            },i*1000)
        })(i)
    }
    //0秒打出5,1秒打出5,2秒打出5,3秒打出5,4秒打出5,
for(var i=0;i<5;i++){
        setTimeout(function(i){
            console.log(i)
        }(i),i*1000)
    }
    //立即执行0,1,2,3,4,定时器每过1秒输出一个undefined
        //拆开以后等同于
    for(var i=0;i<5;i++){
        var t1=function(i){
            console.log(i)
        }
        var t3=t1(i)
        var t2=i*1000
        setTimeout(t3,t2)
    }

相关文章

网友评论

      本文标题:计时器

      本文链接:https://www.haomeiwen.com/subject/kojayxtx.html