关于reflow

作者:Realazy 来源:Realazy 时间:2007-09-23 13:30:00 

去听了牛人 dbaron 的一个 Web Page Layout/Display in Mozilla 讲座( via )。讲的东西对我一个只会HTML, CSS和JavaScript的人来说很底层,所以效果也比较“和谐”,只是大致了解了mozilla的CSS渲染源码分布位置和渲染流程而已。

讲座提到了reflow(如何翻译呢?又是一个问题)这个东东。之前对reflow有所闻,能经常从某些大牛的幻灯中提到,提高页面渲染的性能,需尽量避免reflow. 那么reflow是什么东西呢?它又是如何影响页面性能的?事后去问了一下dbaron(呵呵,我口语彻底不行,加上心理素质,最后是把问题写下来给他看),豁然开朗也。

在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
0
投稿

猜你喜欢

  • MySQL配置文件my.cnf中文版

    2011-09-30 11:06:15
  • CGArt®2008 贺岁刊电子杂志玉鼠闹春

    2008-02-15 08:59:00
  • 如何在asp中创建DSN?

    2009-11-14 20:46:00
  • SQL server使用自定义函数以及游标

    2011-11-03 17:26:27
  • SQL 判断给定日期值(或时间段)所在星期的星期一和星期天的日期

    2011-10-24 20:14:52
  • 傲游对开发人员的影响越来越大了

    2009-10-14 13:16:00
  • PHP正则表达式替换<pre>标签外的内容

    2023-05-22 10:47:12
  • 加密SQL Anywhere 提升政府行业数据安全

    2008-12-03 15:25:00
  • XML 增、删、改和查示例

    2008-09-05 17:12:00
  • asp sql数据验证之特殊字符处理

    2008-02-24 16:35:00
  • 在Oracle中向视图中插入数据的方法

    2009-02-28 10:42:00
  • 设计的技术含量

    2009-01-12 18:20:00
  • 使table也能overflow:hidden

    2008-08-18 21:04:00
  • 用ASP木马实现FTP和解压缩

    2008-02-13 08:47:00
  • asp分段插入数据库

    2010-07-02 13:13:00
  • 两组字符串数据比较合并相同数据

    2008-07-31 17:27:00
  • 实例解析:MySQL 实例管理器识别的命令

    2009-02-23 17:33:00
  • Update 语句

    2009-06-22 12:52:00
  • 和server XMLHTTP相关的几个函数

    2008-09-21 13:56:00
  • CSS资料中常见英语词语翻译整理

    2008-08-29 12:50:00
  • asp之家 网络编程 m.aspxhome.com