当前位置:网站首页>setTimeout, setInterval requestAnimationFrame

setTimeout, setInterval requestAnimationFrame

2022-08-03 12:25:00 rananie

setTimeout 、setInterval、requestAnimationFrame

面试题

  • setTimeout(cb, 0)Will it be implemented immediately??
  • settimeoutIs the timing accurate?? why not accurate? 怎么解决?
  • setTimeout和requestAnimation的区别
  • requestAnimationFrame讲一下你的理解
  • setTimeout实际延迟时间
  • 用setTimeout实现setInterval,To implement a version to stop at any time
  • setTimeout 和 setInterval区别
  • JS实现动画的方式
  • requestAnimationFrame与requestIdleCallback分别是什么?
  • requestAnimationFrame的执行时机?
  • 事件循环,宏任务微任务,requestanimationframeDo a lot of calculations in the callback function,Blocks rendering of the page

setTimeoutThe timer time accurate?

setTimeouttime refers tomsThen put the callback function into the macro queue,当时间为0时,

  • 在nodejs中 setTimeout(demo, 0) === setTimeout(demo, 1),最小是1ms
  • 在浏览器里面 setTimeout(demo, 0) === setTimeout(demo, 4),最小是4ms
    在事件循环中,After executing the synchronous code first,The tasks in the micro-queue need to be executed first,then to the macro queue,So the timer event is inaccurate

setTimeout 和 setInterval

setTimeout(fn,time):Execute the callback function once after the specified time
setInterval(fn,time):Periodically perform callback function

setInterval存在的问题
1.某些间隔被跳过;
2.actual code execution interval <= 设定的时间间隔

假设,某个onclick事件处理程序使用setInterval()设置了200ms间隔的定时器.如果事件处理程序花了300ms多一点时间完成,同时定时器代码也花了差不多的时间,就会同时出现跳过某间隔的情况
在这里插入图片描述使用setTimeout构造轮询能保证每次轮询的间隔

  setTimeout(function fn() {
    
    // do something
    setTimeout(fn, delay)
  }, delay)

When a timer finishes executing,start another timer.
这样做的好处 ①在前一个定时器代码执行完之前,不会向队列插入新的定时器代码,确保不会有任何缺失的间隔.② 它可以保证在下一次定时器代码执行之前,至少要等待指定的间隔,避免了连续的运行.

用setTimeout实现setInterval,可以随时停止

function mySetTimeout(fn,delay){
    
  let timer = null;
  let interval = ()=>{
    
    fn();
    timer = setTimeout(interval,delay); //Start the follow-up timer,Cancellation is also cancellation subsequent
  }
  setTimeout(interval,delay); //The first time the timer is called
  return {
    
    cancel:()=>{
    
      clearTimeout(timer);
    }
  }
}

const {
     cancel } = mySetTimeout(() => console.log(888),1000)
setTimeout(()=>{
    
  cancel()
},4000)

requestAnimationFrame H5新增API

JSHow to implement animation

  • setTimeout
  • setInterval
  • requestAnimationFrame

显示器的刷新频率是60Hz,浏览器也会尽量保持60Hz的刷新率运行,也就是16.7msrefresh one frame so(60次/s)

requestAnimationFrame是什么?
requestAnimationFrame是H5新增的API类似于setTimeout ,告诉浏览器希望执行一个动画,并且要求浏览器在Call the specified callback function before the next repaint.主要用途是Redraw the web page frame by frame.

requestAnimationFrameThe basic idea is to keep pace with the refresh rate of the display,Use this refresh rateperform page redraw.

setTimeout 和requestAnimationFrame 的区别

类型When the callback function is executedIs it running in the background all the time?丢帧现象
setTimeoutUser specified time,put in the macro queue,The final execution time is uncertain
Due to the uncertainty of execution time,setTimeoutThe execution pace may be inconsistent with the refresh pace of the screen,从而引起丢帧现象.
requestAnimationFrame由系统决定回调函数的执行时机,在下次重绘之前调用×
它会在页面出现的时候才会执行,一旦页面不处于浏览器的当前标签,就会自动停止刷新
原因:当页面处于未激活的状态下,The screen refresh task of this page will be suspended by the system
×
Calling before redraw does not drop frames

requestIdleCallback

The browser needs to complete the following six steps in one frame

  • 处理用户的交互

  • JS 解析执行

  • 帧开始.窗口尺寸变更,页面滚去等的处理

  • requestAnimationFrame(rAF)

  • 布局

  • 绘制

  • requestAnimationFrameCalled every time the screen is refreshed

  • requestIdleCallbackon every screen refresh,判断当前帧是否还有多余的时间(上述6After the steps are performed),如果有,则会调用requestIdleCallback的回调函数,

原网站

版权声明
本文为[rananie]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/215/202208031210454043.html