页面重构应注意的repaint和reflow

作者:kllb520 来源:蓝色经典 时间:2011-03-31 17:11:00 

最近了解了下repaintreflow的相关知识,觉得在页面重构过程中就应该考虑前端开发(js)人员对dom进行操作,能够减轻客户浏览器的鸭梨。
在这里整理了一下相关资料,推荐看帖子底部的文章,如果觉得排版不够好请移步我的博客围观。这是一个讨论帖,抛砖引玉,大家说说自己工作中的经验~

1. 什么是 repaint 和 reflow?

一个页面由两部分组成:
DOM:描述该页面的结构
render:描述 DOM 节点 (nodes) 在页面上如何呈现

当 DOM 元素的属性发生变化 (如 color) 时, 浏览器会通知 render 重新描绘相应的元素, 此过程称为 repaint。

如果该次变化涉及元素布局 (如 width), 浏览器则抛弃原有属性, 重新计算并把结果传递给 render 以重新描绘页面元素, 此过程称为 reflow。

这两个过程是很耗费浏览器性能的, 从 IE 系列和 Chrome 渲染页面速度上的差距即可看出渲染引擎计算对应值和呈现并不一定高效, 而每次对元素的操作都会发生 repaints 或 reflow, 因此编写 DOM 交互时如果不注意就会导致页面性能低下.
页面渲染的过程如下:

1.解析HTML代码并生成一个 DOM 树。

2.解析CSS文件,顺序为:浏览器默认样式->自定义样式->页面内的样式。

3.生成一个渲染树(render tree)。这个渲染树和DOM树的不同之处在于,它是受样式影响的。它不包括那些不可见的节点。

4.当渲染树生成之后,浏览器就会在屏幕上“画”出所有渲染树中的节点。

2. 什么情况下会触发浏览器的repaint/reflow?

除了页面在首次加载时必然要经历该过程之外,还有以下行为会触发这个行为:

引用:
1. DOM元素的添加、修改(内容)、删除( Reflow + Repaint)
2. 仅修改DOM元素的字体颜色(只有Repaint,因为不需要调整布局)
3. 应用新的样式或者修改任何影响元素外观的属性
4. Resize浏览器窗口、滚动页面
5. 读取元素的某些属性(offsetLeft、offsetTop、offsetHeight、offsetWidth、 scrollTop/Left/Width/Height、clientTop/Left/Width/Height、 getComputedStyle()、currentStyle(in IE))

3. 怎么优化?

1. 避免在document上直接进行频繁的DOM操作,如果确实需要可以采用off-document的方式进行,具体的方法包括但不完全包括以下几种:


引用:
1. 先将元素从document中删除,完成修改后再把元素放回原来的位置
2. 将元素的display设置为”none”,完成修改后再把display修改为原来的值
3. 如果需要创建多个DOM节点,可以使用DocumentFragment创建完后一次性的加入document

2. 集中修改样式


引用:
       1. 尽可能少的修改元素style上的属性
       2. 尽量通过修改className来修改样式
       3. 通过cssText属性来设置样式值

3. 缓存Layout属性值


引用:
       对于Layout属性中非引用类型的值(数字型),如果需要多次访问则可以在一次访问时先存储到局部变量中,之后都使用局部变量,这样可以避免每次读取属性时造成浏览器的渲染。

4. 设置元素的position为absolute或fixed


引用:
       在元素的position为static和relative时,元素处于DOM树结构当中,当对元素的某个操作需要重新渲染时,浏览器会渲染整个页 面。将元素的position设置为absolute和fixed可以使元素从DOM树结构中脱离出来独立的存在,而浏览器在需要渲染时只需要渲染该元素 以及位于该元素下方的元素,从而在某种程度上缩短浏览器渲染时间,这在当今越来越多的Javascript动画方面尤其值得考虑。

5. 权衡速度的平滑


引用:
       比如实现一个动画,以1个像素为单位移动这样最平滑,但reflow就会过于频繁,CPU很快就会被完全占用。如果以3个像素为单位移动就会好很多。

6. 不要用tables布局


引用:
       不要用tables布局的另一个原因就是tables中某个元素一旦触发reflow就会导致table里所有的其它元素 reflow。在适合用table的场合,可以设置table-layout为auto或fixed,这样可以让table一行一行的渲染,这种做法也是为了限制reflow的影响范围

7. 不要在css里面写expression


引用:
       很多情况下都会触发reflow,如果css里有expression,每次都会重新计算一遍

参考文章:

       1. 如何减少浏览器repaint和reflow
       2. Repaint, reflow/relayout, restyle
       3. Reflows & Repaints: CSS Performance making your JavaScript slow?
       4. Repaint 跟踪浏览器的渲染[如果你的FF是3.5beta+监听网页的重绘情况]

标签:repaint,reflow,页面重构
0
投稿

猜你喜欢

  • utf-8 网页不显示+utf-8网页乱码的通用解决方法

    2011-04-19 10:47:00
  • 网站图片与文本谁更重要?(中英文对照)

    2008-10-17 10:25:00
  • asp中常用的字符串安全处理函数集合(过滤特殊字符等)

    2011-02-20 10:40:00
  • 深入透析样式表滤镜(上)

    2011-06-14 09:48:40
  • 用SQL语句完成SQL Server数据库的修复

    2008-11-24 20:49:00
  • 判断浏览器是否接受 Cookie

    2009-07-28 17:52:00
  • javascript新闻图片轮换类

    2009-01-09 12:57:00
  • 如何高效地访问记录集?

    2009-11-22 19:25:00
  • MySQL 基本概念

    2011-09-10 16:22:34
  • asp生成不需要数据库的中奖码

    2008-07-18 12:31:00
  • 如何避免SQL语句中含有单引号而导致操作失败?

    2009-11-07 18:40:00
  • z-blog文章摘要图文混排

    2009-02-28 13:49:00
  • 面向对象设计过程中必须遵守的相关准则

    2009-01-08 15:52:00
  • jquery弹出层背景变暗 Lee dialog

    2008-08-18 13:11:00
  • 关于利用:first-letter实现首字下沉的一些看法

    2010-04-20 17:19:00
  • 10分钟学会Google Map API (一)

    2009-06-07 18:17:00
  • 网页对联广告代码效果大全

    2007-10-25 23:16:00
  • asp如何让我的网页自动适应客户端的屏幕分辨率?

    2010-05-13 16:38:00
  • css基础教程之序曲

    2008-07-23 12:40:00
  • 实例讲解如何配置MySQL数据库主从复制

    2008-12-17 15:33:00
  • asp之家 网络编程 m.aspxhome.com