浏览器的重绘与重排

120 阅读2分钟

这是我参与8月更文挑战的第6天,活动详情查看:8月更文挑战

前端开发者在项目开发过程中需要特别注意浏览器的重绘(redraw)和重排(reflow),浏览器的重绘和重排直接影响着系统的性能。

一、什么是浏览器的重绘和重排

浏览器从开始请求资源到显示页面的过程就包含了重绘和重排。通常在文档初次加载时,浏览器引擎会解析HTML文档来构建DOM树,之后根据DOM元素的几何属性构建一棵用于渲染的树。渲染树的每个节点都有大小和边距等属性,类似于盒子模型(由于隐藏元素不需要显示,渲染树中并不包含DOM树中隐藏的元素)。当渲染树构建完成后,浏览器就可以将元素放置到正确的位置了,再根据渲染树节点的样式属性绘制出页面。由于浏览器的流布局,对渲染树的计算通常只需要遍历一次就可以完成。

重绘是一个元素外观的改变所触发的浏览器行为,浏览器会根据元素的新属性重新绘制,使元素呈现新的外观。
例如改变visibility、outline、背景色等属性。
重排是更明显的一种改变,可以理解为渲染树需要重新计算。
例如DOM元素的几何属性变化、DOM树的结构变化、DOM树的结构变化等。

二、减少重排的影响

开发过程中尽量减少重排次数和缩小重排的影响范围,具体表现:
1、将多次改变样式属性的操作合并成一次操作。
2、将需要多次重排的元素,position属性设为absolute或fixed,这样此元素就脱离了文档流,它的变化不会影响到其他元素。
3、在需要经常获取那些引起浏览器重排的属性值时,要缓存到变量。
4、在内存中多次操作节点,完成后再添加到文档中去。 5、如果要对一个元素进行复杂的操作时,可以先隐藏它,操作完成后再显示。这样只在隐藏和显示时触发2次重排。