IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

Reflow

163 UED Team 2009-11-16 23:24:16 累计浏览 2,453 次
本机暂存

    在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元素还是它的父元素甚至更多祖先元素?

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

同分类推荐文章

  1. translateZ() (2026-06-25 21:18:56)
  2. translateY() (2026-06-25 21:17:56)
  3. translateX() (2026-06-25 21:16:01)

查看更多 前端 文章 →

建议继续学习

  1. 50个活力和动感的网页设计-颜色的灵感 (累计阅读 34,443)
  2. 视觉设计前瞻实用性研究(PNVD) 第二期 (累计阅读 12,979)
  3. 各公司对前端开发的职位描述 (累计阅读 10,407)
  4. iframe大小自适应 (累计阅读 10,059)
  5. jQuery的data()方法 (累计阅读 8,652)
  6. 浏览器的渲染原理简介 (累计阅读 8,377)
  7. 解决IE6从Nginx服务器下载图片不Cache的Bug (累计阅读 8,358)
  8. 用javascript来摧毁你所访问的网站 (累计阅读 8,225)
  9. 程序员眼里IE浏览器是什么样的 (累计阅读 8,011)
  10. 2010网页设计趋势 (累计阅读 7,819)