页面重绘、回流、重排

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/running_shuai/article/details/81000072

前言:

DOM Tree 和样式结构体组合后构建render tree

回流重排(重构/回流/reflow)

当render tree中的一部分(或全部)因为元素的规模尺寸,布局,隐藏等改变而需要重新构  
建。这就称为回流(reflow),每个页面至少需要一次回流,就是在页面第一次加载的时候。
在回流的时候,浏览器会使渲染树中受到影响的部分失效,并重新构造这部分渲染树,完成回流  
后,浏览器会重新绘制受影响的部分到屏幕中,该过程成为重绘。

回流何时发生

当页面布局和几何属性改变时就需要回流。下述情况会发生浏览器回流:

1、添加或者删除可见的DOM元素;

2、元素位置改变;

3、元素尺寸改变——边距、填充、边框、宽度和高度

4、内容改变——比如文本改变或者图片大小改变而引起的计算值宽度和高度改变;

5、页面渲染初始化;

6、浏览器窗口尺寸改变——resize事件发生时;

重绘

当render tree中的一些元素需要更新属性,而这些属性只是影响元素的外观,风格,而不会  
影响布局的,比如background-color。则就叫称为重绘。

如何减少回流、重绘

减少回流、重绘其实就是需要减少对render tree的操作(合并多次多DOM和样式的修改)
a) 使用DocumentFragment进行缓存操作,引发一次回流和重绘;
b) 使用display:none技术,只引发两次回流和重绘;
c) 使用cloneNode(true or false) 和 replaceChild 技术,引发一次回流和重绘;

猜你喜欢

转载自blog.csdn.net/running_shuai/article/details/81000072