浅谈setInterval和setTimeout的区别

最近使用到了倒计时,查看了下资料发现有定时器setInterval和setTimeout可以实现倒计时,

1.setTimeout(loop,3000)和setInterval(loop,3000)这两个函数的作用都是隔3秒执行loop这个函数,

两者的差距的是:setTimeout()只执行一次那段代码,而setInterval()在执行完一次代码之后,经过了3秒,它还会自动重复执行loop函数(类似于递归)

例如:

1、setInterval(loop,3000),在执行完一次代码后,它自己会自动执行

 

setInterval(loop,3000);
function loop(){
    alert("需要执行的代码");
}

2、如果setTimeout(loop,3000);需要进行循环执行的话,需要使用递归的方法 

function loop(){
    alert("执行的代码");
    setTimeout(loop,3000);
}

 其中两者的区别是,setInterval(loop,3000)是经过3秒执行一次,不会随着loop里面函数的变化而变化,但是setTimeout(loop,3000)

表示loop函数执行完后,经过三秒后在执行loop,如果loop函数执行需要1秒,那么整个循环执行之间相隔4秒。

场景:所以对于明确一定时间内进行循环的使用setInterval函数,但是如果不想由于连续调用产生互相干扰的问题,尤其是每次函数的调用需要繁重的计算以及很长的处理时间,那么最好使用setTimeout。

另外清除定时器,clearInterval(interValid),

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值