美文网首页让前端飞Web前端之路JavaScript 进阶营
javascript总结:setTimeout模拟setInte

javascript总结:setTimeout模拟setInte

作者: 张培跃 | 来源:发表于2019-08-14 22:29 被阅读16次
  • 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—————
喜欢本文的朋友们,欢迎关注公众号 张培跃,收看更多精彩内容!!!公众号回复 电子书 ,送你经典电子书籍!

相关文章

网友评论

    本文标题:javascript总结:setTimeout模拟setInte

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