Reflow

作者:mike 来源:163 UED 时间:2009-10-25 12:34:00 

在CSS规范中有一个渲染对象的概念,通常用一个盒子(box, rectangle)来表示。mozilla通过一个叫frame的对象对盒子进行操作。frame主要的动作有三个:

* 构造frame, 以建立对象树(DOM树)
* reflow, 以确定对象位置,或者是调用mozilla的Layout(这里是指源码的实现)
* 绘制,以便对象能显示在屏幕上

总的来说,reflow就是载入内容树(在HTML中就是DOM树)和创建或更新frame结构的响应的一种过程。

要提高页面性能,其实就是避免reflow的开销。那么,有哪些方面是需要reflow的呢?比如,未指定图片宽高的话,图片的载入会使页面 reflow, 因为要根据图片宽高来更新frame。这里就有一个提高页面性能的小技巧:如果事先能够确定图片宽高的话,最好在HTML里写上。

在编写一些常见的动态效果时,一般使用CSS的display来切换可见性。很不幸,这也会产生reflow. 把元素置为display:none,相当于把这个元素的frame销毁了,再置回非none时,需要重新构造frame,这就产生了reflow. 而另外一个切换可见性的属性visibility则不存在reflow问题,置为visibility:hidden的元素的frame并没有销毁,需要显示的时候其实就是一个绘制(上面提到的动作第三步)过程而已,没有reflow,因此效率会更高。如果你看过一些JavaScript库/框架的源码,会发现它们大量使用visibility而不是display,道理应该如此。

根据文中提到的reflow,想到的疑点:

<div>
<div>…content…</div>
<div><img src=”‘ /></div>
</div>

当在HTML里没指定图片的宽高时,reflow只是针对img元素还是它的父元素甚至更多祖先元素?

在常规页面中大量用到的标签切换情况也类似?你知道吗?

标签:frame,reflow,对象,css
0
投稿

猜你喜欢

  • sqlserver 2000中创建用户的图文方法

    2012-03-26 18:26:39
  • 一行CSS代码为网站加上奥运主题

    2008-07-20 12:33:00
  • 如何以及何时使用sIFR

    2008-03-07 12:38:00
  • SQL 2005 sa islock用户不能正常登录的现象

    2008-12-05 15:49:00
  • ASP同一站点不同编码程序出现乱码解决办法

    2008-11-10 12:08:00
  • ASP,PHP与.NET伪造HTTP-REFERER方法及防止伪造REFERER的方法

    2010-03-12 12:40:00
  • 栅格:灵活应变

    2008-07-22 12:22:00
  • 详解css定位与定位应用

    2007-05-11 16:52:00
  • [JS效果]动画效果打开/关闭/移动层

    2008-04-10 11:42:00
  • asp随机生成文件名的函数

    2009-02-11 13:41:00
  • 常用于后台开发的jQuery插件

    2010-09-25 12:47:00
  • mysql数据库你需要特别注意的23个事项

    2010-08-08 08:34:00
  • ASP处理XSLT转换XML的实现

    2008-10-20 18:37:00
  • ASP程序开发注意的安全事项

    2010-05-03 10:55:00
  • Flash在web客户端的潜在问题

    2009-05-20 12:11:00
  • AJAX打造博客无刷新搜索

    2007-08-23 08:48:00
  • 汇总数据库备份 还原 压缩与数据库转移的方法

    2009-01-19 14:07:00
  • ASP网站数据采集经验谈

    2008-03-09 15:30:00
  • 低效的键盘和高效的登录框

    2007-08-22 09:17:00
  • sql分类汇总及Select的自增长脚本

    2012-07-21 14:40:14
  • asp之家 网络编程 m.aspxhome.com