沃梦达 / IT编程 / 前端开发 / 正文

详解盒子端CSS动画性能提升

不同于传统的PC Web或者是移动WEB,在腾讯视频客厅盒子端,接大屏显示器下,许多能流畅运行于PC端、移动端的Web动画,受限于硬件水平,在盒子端的表现的往往不尽如人意。想要在盒子端跑出高性能接近60 FPS的流畅动画,就必须要刨根问底,深

这里,我们明确使得.swiper的层级高于.list,再打开开发者工具观察一下:

4. 使用 will-change 可以在元素属性真正发生变化之前提前做好对应准备


// 示例
.example {
    will-change: transform;
}

上面已经提到过 will-change 了。

will-change 为 web 开发者提供了一种告知浏览器该元素会有哪些变化的方法,这样浏览器可以在元素属性真正发生变化之前提前做好对应的优化准备工作。 这种优化可以将一部分复杂的计算工作提前准备好,使页面的反应更为快速灵敏。

值得注意的是,用好这个属性并不是很容易:

在一些低端盒子上,will-change会导致很多小问题,譬如会使图片模糊,有的时候很容易适得其反,所以使用的时候还需要多加测试。

不要将 will-change 应用到太多元素上:浏览器已经尽力尝试去优化一切可以优化的东西了。有一些更强力的优化,如果与 will-change 结合在一起的话,有可能会消耗很多机器资源,如果过度使用的话,可能导致页面响应缓慢或者消耗非常多的资源。

有节制地使用:通常,当元素恢复到初始状态时,浏览器会丢弃掉之前做的优化工作。但是如果直接在样式表中显式声明了 will-change 属性,则表示目标元素可能会经常变化,浏览器会将优化工作保存得比之前更久。所以最佳实践是当元素变化之前和之后通过脚本来切换 will-change 的值。

不要过早应用 will-change 优化:如果你的页面在性能方面没什么问题,则不要添加 will-change 属性来榨取一丁点的速度。 will-change 的设计初衷是作为最后的优化手段,用来尝试解决现有的性能问题。它不应该被用来预防性能问题。过度使用 will-change 会导致生成大量图层,进而导致大量的内存占用,并会导致更复杂的渲染过程,因为浏览器会试图准备可能存在的变化过程,这会导致更严重的性能问题。

给它足够的工作时间:这个属性是用来让页面开发者告知浏览器哪些属性可能会变化的。然后浏览器可以选择在变化发生前提前去做一些优化工作。所以给浏览器一点时间去真正做这些优化工作是非常重要的。使用时需要尝试去找到一些方法提前一定时间获知元素可能发生的变化,然后为它加上 will-change 属性。

5. 使用 dev-tool 时间线 timeline 观察,找出导致高耗时、掉帧的关键操作

1)对比屏幕快照,观察每一帧包含的内容及具体的操作

2)找到掉帧的那一帧,分析该帧内不同步骤的耗时占比,进行有针对性的优化

3)观察是否存在内存泄漏

对于 timeline 的使用用法,这里有个非常好的教程,通俗易懂,可以看看:

浏览器渲染优化 Udacity 课程

总结一下

对于盒子端 CSS 动画的性能,很多方面仍处于探索中,本文大量内容在之前文章已经出现过,这里更多的是归纳总结提炼成可参照执行的流程。

本文的优化方案研究同样适用于 PC Web 及移动 Web

以上就是详解盒子端CSS动画性能提升的详细内容,更多关于盒子端CSS动画性能提升的资料请关注编程学习网其它相关文章!

本文标题为:详解盒子端CSS动画性能提升