-
setTimeout
和setInterval
的语法相同。它们都有两个参数,一个是将要执行的代码字符串,还有一个是以毫秒为单位的时间间隔。
setInterval(()=>{}, 1000);
setTimeout(()=>{}, 1000);
- 区别:
setInterval
在执行完一次代码之后,经过指定的时间间隔,执行代码,而setTimeout
只执行一次那段代码。 - 注意:假设
setTimeout
定时器指定时间为1秒,而函数的执行时间是2秒,则setTimeout
的总运行总时长为3秒。而setInterval
不会被调用的函数所束缚,它只是简单地每隔一定时间就重复执行一次指定的函数。所以在函数的逻辑比较复杂,所处理的时间较长时,setInterval
有可能会产生连续干扰的问题。若要避免这一问题,建议通过setTimeout
来模拟一个setInterval
。
实现:
// 可避免setInterval因执行时间导致的间隔执行时间不一致
setTimeout (function () {
// do something
setTimeout (arguments.callee, 500)
}, 500)
—————END—————
喜欢本文的朋友们,欢迎关注公众号 张培跃,收看更多精彩内容!!!公众号回复 电子书 ,送你经典电子书籍!
网友评论