动画性能优化实用方法整理

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

【页面渲染过程】

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属性为absolute或fixed的元素,重排的开销会比较小,因为不用考虑它对其他元素的影响。

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,二者过于耗性能

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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,530评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,403评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,120评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,770评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,758评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,649评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,021评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,675评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,931评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,751评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,410评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,004评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,969评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,042评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,493评论 2 343

推荐阅读更多精彩内容