html之重绘与重排
此题涉及到html的性能,首先了解一下浏览器的运行机制
1 浏览器运行机制
1.构建DOM树:渲染引擎解析HTML文档。首先将标签转换成DOM树中的DOM node(包括js生成的标签)生成内容树。
2.构建渲染树:解析对应的CSS样式文件信息(包括js生成的样式和外部css文件),这些文件信息以及HTML中可见的指令,构建渲染树。渲染树中每个node都有自己的stylee,并且渲染树不包含隐藏的节点(比如display:none,还有head节点),因为这些节点不会用于呈现。
3.布局渲染树:从根节点递归调用,计算每一个元素的大小,位置等,给出每个节点所应该在屏幕上面显示的精确坐标。
4.绘制渲染树:遍历渲染树,使用UI层绘制每个节点。
2 何为重绘
当盒子的位置、大小以及其他属性,例如颜色、字体大小等都确定下来后,浏览器便把这些原色都按照各自的特性绘制一遍,将内容呈现在页面。
重绘(repaint):指一个元素外观的改变所触发的浏览器的行为,浏览器会根据元素的新属性重新绘制,使元素呈现新的外观。
触发重绘条件:改变元素外观,如:color
注意: table及其内部元素可能需要多次计算才能确定好其在渲染树中节点的属性值,比同等元素要多花两倍时间,这就是我们尽量避免使用table布局页面的原因之一。
3 何为重排
重排(重构/回流/reflow):当渲染树中的一部分(或全部)因为元素的规模尺寸,布局,隐藏等改变而需要重新构建,这就称为回流(reflow)。每个页面至少需要一次回流,就是在页面第一次加载的时候。
触发重排的条件:任何页面布局和几何属性的改变都会触发重排,如:
1、页面渲染初始化(无法避免);
2、添加或删除可见的DOM元素;
3、元素位置的改变,或者使用动画;
4、元素尺寸的改变―—大小,外边距,边框;
5、浏览器窗口尺寸的变化(resize事件发生时);
6、填充内容的改变,比如文本的改变或图片大小改变而引起的计算值宽度和高度的改变;
7、读取某些元素属性: (offsetLeft/Top/Height/Width,clientTop/Left/width/Height,scrollTop/Left/Width/Height,width/height,getComputedstyle(), currentStyle(IE) )
重绘重排的代价:耗时,导致浏览器卡慢。
重绘和重排的关系:在回流的时候,浏览器会使渲染树中受到影响的部分失效,并重新构造这部分渲染树,完成回流后,浏览器会重新绘制受影响的部分到屏幕中,该过程称为重绘。
所以,重排必定会引发重绘,但重绘不一定会引发重排。
4 优化
1、浏览器自己的优化:浏览器会维护1个队列,把所有会引起回流、重绘的操作放入这个队列,等队列中的操作到了一定的数量或者到了一定的时间间隔,浏览器就会flush队列,进行一个批处理。这样就会让多次的回流、重绘变成一次回流重绘。
2、我们要注意的优化:我们要减少重绘和重排就是要减少对渲染树的操作,则我们可以合并多次的DOM和样式的修改。并减少对style样式的请求。
(1)直接改变元素的className
(2) display: none;先设置元素为display: none;然后进行页面布局等操作;设置完成后将元素设置为display: block:这样的话就只引发两次重绘和重排;
(3)将需要多次重排的元素,position属性设为absolute或fixed,元素脱离了文档流,它的变化不会影响到其他元素:|
(4)如果需要创建多个DOM节点,可以使用DocumentFragment创建完后一次性的加入document;
- 本文作者: étoile
- 版权声明: 本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。转载请注明出处!