关于reflow

2016-02-19 13:08 15 1 收藏

岁数大了,QQ也不闪了,微信也不响了,电话也不来了,但是图老师依旧坚持为大家推荐最精彩的内容,下面为大家精心准备的关于reflow,希望大家看完后能赶快学习起来。

【 tulaoshi.com - Web开发 】

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

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

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

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

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

构造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,道理应该如此

来源:http://www.tulaoshi.com/n/20160219/1603057.html

延伸阅读
三向免疫调节的作用 婴幼儿期的小宝宝正处在一个高速成长的阶段,可是疾病却不时打断宝宝的正常成长。所以增强宝宝机体的免疫力就显得尤为重要。只有免疫力增强了,宝宝的体质才能更强壮,才能更有效地抵御疾病,即便是不幸患病,也能够尽快地恢复健康。 大量的统计数据显示,凡是母乳喂养的宝宝,其机体免疫力的表现都非常出色。近年来国内...
在前面的图形绘制中,我们已经接触到了节点,初步了解到矢量图形的形状是由节 点控制的,并能简单的控制节点改变图形的形状。 控制点 是节点上的用于调节曲线形状的特殊的点。由于曲线的形状是由曲线上的节点及节 点上的控制点所决定的,因此通过移动节点和调节节点的控制点,可以改变曲线...
在工程文件中Application.Run语句之前加入下面语句,可不让主Form在运行时显示:       Application.ShowMainForm := False; 显示设置时间的对话框    ShellExecute(Handle, 'open', 'control', 'date/time', nil, SW_SHOW); FormatDateTime('yyyy mmm...
标签: PHP
Zend Optimizer(以下简称ZO)用优化代码的方法来提高PHP 4.0应用程序的执行速度。实现的原理是对那些在被最终执行之前由运行编译器(Run-Time Compiler)产生的代码进行优化。 优化能提高你的盈利能力 一般情况下,执行使用ZO的PHP程序比不使用的要快40%到100%。这意味着网站的访问者可以更快的浏览网页,从而完成更多的事务,创造...

经验教程

381

收藏

68
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部