动画性能优化实用方法整理_动画性能如何优化-程序员宅基地

技术标签: CSS  

一、动画性能优化原理简述

【页面渲染过程】

   1.javascript/css设置动画或变换

    2.【计算样式】

       根据css选择器,对每个DOM元素匹配对应的CSS样式。

       从而确定每个DOM元素上应该应用什么CSS样式规则。

     3.【布局】

       计算每个DOM元素最终在屏幕上显示的大小和位置。

     4.【绘制】

       本质上就是填充像素的过程。

       包括绘制文字、颜色、图像、边框和阴影等,也就是一个DOM元素所有的可视效果。

一般来说,这个绘制过程是在多个层上完成的。

     5.【渲染层合并】

在每个层上完成绘制过程之后,浏览器会将所有层按照合理的顺序合并成一个图层,

然后在屏幕上呈现。


【导致重排的因素】

  1.调整窗口大小

  2.改变字体

  3.增加或者移除样式表

  4.内容变化

  5.激活CSS伪类

  6.操作CSS属性

  7.JavaScript操作DOM

  8.计算 offsetWidth和 offsetHeight

  9.设置 style 属性的值

  10.CSS3 Animation或Transition


【导致重绘的因素】

  1.页面首次加载

  2.DOM元素添加、修改(内容)和删除(Reflow + Repaint)

  3.仅修改DOM元素的颜色

  4.应用新的样式或修改任何影响元素外观的属性

  5.Resize浏览器窗口和滚动页面

  6.读取元素的某些属性( offsetLeft、 offsetTop、 offsetHeight、 offsetWidth、 getComputedStyle() 等)


优化点一:减少重排、重绘


注:动画效果优选transform、opacity属性,因为二者不会造成页面的重排或重绘。


【生成独立RenderLayer的情况】

  1.页面的根节点的RenderObject

  2.有明确的CSS定位属性( relative , absolute 或者 transform )

  3.是透明的

  4.有CSS overflow、CSS alpha遮罩(alpha mash)或者CSS reflection

  5.有CSS 滤镜(fliter)

  6.3D环境或者2D加速环境的canvas元素对应的RenderObject

  7.video元素对应的RenderObject

 

【生成独立GraphicsLayer的情况】

  1.有3Dtransform或者perspective的CSS属性的层

  2.使用加速视频解码的video元素的层

  3.3D或者加速2D环境下的canvas元素的层

  4.插件,比如flash

  5.对 opacity 和 transform 应用了CSS动画的层

  6.使用了加速CSS滤镜(filters)的层

  7.有合成层后代的层

  8.同合成层重叠,且在该合成层上面(z-index)渲染的层

  9.有backface-visibility属性的层

  10.will-change:transform的层


优化点二:生成独立的RenderLayer(防止动画效果引起页面其他元素的重排)、GraphicsLayer(启用多缓存加速合成)


注:过多的GraphicsLayer会造成过大的内存消耗,特别对移动端性能影响较大,注意适度使用


二、可用优化方法整理

1.【减少重排/重绘】DOM 的多个读操作(或多个写操作),应该放在一起。不要两个读操作之间,加入一个写操作。

2.【减少重排】如果某个样式是通过重排得到的,那么最好缓存结果。避免下一次用到的时候,浏览器又要重排。

3.【减少重排/重绘】不要一条条地改变样式,而要通过改变class,或者csstext属性,一次性地改变样式。


4.【减少重排/重绘】尽量使用离线DOM,而不是真实的网面DOM,来改变元素样式。比如,操作Document Fragment对象,完成后再把这个对象加入DOM。再比如,使用 cloneNode() 方法,在克隆的节点上进行操作,然后再用克隆的节点替换原始节点。

5.【减少重排/重绘】先将元素设为display: none(需要1次重排和重绘),然后对这个节点进行100次操作,最后再恢复显示(需要1次重排和重绘)。这样一来,你就用两次重新渲染,取代了可能高达100次的重新渲染。

6.【生成独立的RenderLayer】position属性为absolutefixed的元素,重排的开销会比较小,因为不用考虑它对其他元素的影响。

7.【减少重排/重绘】只在必要的时候,才将元素的display属性为可见,因为不可见的元素不影响重排和重绘。另外,visibility : hidden的元素只对重绘有影响,不影响重排。

8.使用虚拟DOM的脚本库,比如React等。

9.使用 window.requestAnimationFrame()、window.requestIdleCallback() 这两个方法调节重新渲染,优化js动画

10.【减少重排】 left/top->translate    width/height->scale,rotate,opacity

11.【生成独立的GraphicsLayer】尽可能多的利用硬件能力,开启GPU加速

12. 尽可能少的使用box-shadows与gradients,二者过于耗性能

*动画性能优化方法持续整理中......


文章整理自:
http://www.open-open.com/lib/view/open1475128810681.html
http://www.xuanfengge.com/css3-animations.html
http://www.ruanyifeng.com/blog/2015/09/web-page-performance-in-depth.html

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/z_Sherry/article/details/72123965

智能推荐

王斌老师的博客_王斌 github-程序员宅基地

文章浏览阅读480次。http://blog.sina.com.cn/s/blog_736d0b9101018cgc.html_王斌 github

ACM OJ Collection_htt//acm.wydtang.top/-程序员宅基地

文章浏览阅读737次。原文来自:http://blog.csdn.net/hncqp/article/details/4455263 ACM OJ Collection(排名不分先后):中国:浙江大学(ZJU):http://acm.zju.edu.cn/北京大学(PKU):htt_htt//acm.wydtang.top/

ios 自己服务器 苹果支付_修复苹果IOS支付-程序员宅基地

文章浏览阅读467次。更新记录1.0.0(2019-07-01)插件简介专门用来修复苹果IOS支付时出现"您已购买此App内购买项目。此项目将免费恢复"。问题描述首先在IOS平台里面创建“APP内购买项目”,选择的是“消耗型项目”,然后用uni-app官方的支付api进行支付,多支付几次,有时候就会出现提示“您已购买此App内购买项目。此项目将免费恢复”,特别是在沙盒测试里面支付很大几率出现,我明明选的是消耗型项目,应..._ios开发苹果支付恢复权益

spring MVC mock类单元测试(controller)_mvcmock-程序员宅基地

文章浏览阅读5.6k次。Spring从J2EE的Web端为每个关键接口提供了一个mock实现:MockHttpServletRequest几乎每个单元测试中都要使用这个类,它是J2EE Web应用程序最常用的接口HttpServletRequest的mock实现。MockHttpServletResponse此对象用于HttpServletRespons_mvcmock

【我的世界Minecraft-MC】常见及各种指令大杂烩【2022.8版】_summon生成掉落物-程序员宅基地

文章浏览阅读8.5k次,点赞7次,收藏22次。execute as @a at @s run clear @s minecraft:dark_oak_planks{display:{Name:“{“text”:“第三关[阴森古堡]”,“color”:“red”,“italic”:false}”,color:“16711680”},Enchantments:[{id:“protection”,lvl:1}],Unbreakable:1b} 1。Lore:[“{“text”:“免费”,“color”:“blue”,“italic”:false}”]..._summon生成掉落物

CentOS 7安装教程(图文详解)_centos 安装-程序员宅基地

文章浏览阅读10w+次,点赞487次,收藏2.1k次。CentOS 7安装教程: 准备: 软件:VMware Workstation 镜像文件:CentOS-7-x86_64-bin-DVD1.iso (附:教程较为详细,注释较多,故将操作的选项进行了加粗字体显示。) 1、文件--新建虚拟机--自定义 2、..._centos 安装

随便推点

Github项目分享——免费的画图工具drow,前端插件化面试_draw github画图-程序员宅基地

文章浏览阅读333次,点赞3次,收藏3次。项目介绍一款很好用的免费画图软件,支持ER图、时序图、流程图等等在项目的releases就可以下载最新版本同时支持在线编辑。_draw github画图

如何开始学习人工智能?入门的学习路径和资源是什么?_人工智能学习路径-程序员宅基地

文章浏览阅读930次。嗨,大家好!如果你对人工智能充满了好奇,并且想要入门这个领域,那么你来对地方了。本文将向你介绍如何从零基础开始学习人工智能,并逐步掌握核心概念和技能。无论你是大学生、职场新人还是对人工智能感兴趣的任何人,都可以按照以下学习路径逐步提升自己。_人工智能学习路径

Unity3D 导入资源_unity怎么导入压缩包-程序员宅基地

文章浏览阅读4.3k次,点赞2次,收藏8次。打开Unity3D的:window-asset store就会出来这样的界面:我们选择一个天空纹理,注意这里的标签只有一个,如果有多个就会显示所有标签的内容:找个比较小的免费的下载一下试试,比如这个:下载以后:点击import就会出现该窗口:然后再点击最底下的import:就导入到我们这里来了。从上面可以切换场景:..._unity怎么导入压缩包

jqgrid 服务器端验证,javascript – jqgrid服务器端错误消息/验证处理-程序员宅基地

文章浏览阅读254次。在你以前的问题的the answer的最后一部分,我试着给出你当前的问题的答案.也许我表示不够清楚.您不应该将错误信息放在标准成功响应中.您应该遵循用于服务器和客户端之间通信的HTTP协议的主要规则.根据HTTP协议实现网格中的加载数据,编辑行和与服务器的所有Ajax通信.每个HTTP响应都有响应第一行的状态代码.了解这个意义非常重要.典型的JSON数据成功请求如下HTTP/1.1 200 OK...._decode message error

白山头讲PV: 用calibre进行layout之间的比对-程序员宅基地

文章浏览阅读4k次,点赞8次,收藏29次。我们在流片之后,通常还是有机会对layout进行局部小的修改。例如metal change eco或者一些层次的局部修改。当我们修改之后,需要进行与之前gds的对比,以便确认没有因为某些..._calibre dbdiff

java exit方法_Java:如何测试调用System.exit()的方法?-程序员宅基地

文章浏览阅读694次。问题我有一些方法应该在某些输入上调用567779278。不幸的是,测试这些情况会导致JUnit终止!将方法调用放在新线程中似乎没有帮助,因为System.exit()终止了JVM,而不仅仅是当前线程。是否有任何常见的处理方式?例如,我可以将存根替换为System.exit()吗?[编辑]有问题的类实际上是一个命令行工具,我试图在JUnit中测试。也许JUnit根本不适合这份工作?建议使用互补回归测..._检查system.exit