javascript总结:setTimeout模拟setInterval

版权声明:本文为博主原创文章,遵循 CC 4.0 BY 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/u012149969/article/details/99616738
  • setTimeoutsetInterval的语法相同。它们都有两个参数,一个是将要执行的代码字符串,还有一个是以毫秒为单位的时间间隔。
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—————
喜欢本文的朋友们,欢迎关注公众号 张培跃,收看更多精彩内容!!!公众号回复 电子书 ,送你经典电子书籍!

猜你喜欢

转载自blog.csdn.net/u012149969/article/details/99616738