尝试了解RequestAnimationFrame及其内部工作原理。浏览器有一个主线程,它是一个事件循环。事件循环可以填充各种异步事件,例如用户交互、定时器被触发、网络调用完成以及触发布局和绘制的事件,例如输入或JS。因此,当JS函数使DOM布局无效或导致重新绘制时,浏览器的主线程重新绘制需要更新的图层,合成器线程将更新后的纹理上传到GPU,最终合成发生并显示结果图像到屏幕上。因此,我的印象是浏览器仅在实际需要时才执行绘制。如果您在静态页面上捕获ChromeDevTools时间轴上的事件而没有发生任何事情,则绝对不会捕获任何事件(没有布局、没有绘制、没有触发动画帧)。说得通。然后你在控