前端每日一读,大厂面试无忧:网络与安全—浏览器渲染流程、重排
文章标签:
html 选择器
哈咯~ 大家好~ 又是美好的一天,前端小菜鸟上线啦,为大家带来今天的“前端每日一读,大厂面试无忧”——浏览器渲染流程,重排、重绘,以及如何避免重排和重绘
浏览器的渲染流程是一个包含多个步骤的复杂过程,主要涉及以下环节
浏览器渲染流程
1.解析HTML构建DOM树:
- 浏览器解析HTML文件,创建DOM树
2.解析CSS构建CSSOM树:
- 解析CSS文件和样式,构建CSS对象模型(CSSOM)树。
3.合并DOM和CSSOM构建渲染树:
- 将DOM和CSSOM合并,创建渲染树,这一步确定每个节点的样式。
4.布局(Layout):
- 计算渲染树中每个节点的准确位置和大小。
5.分层(Layering):
- 一些元素(如具有复杂效果的元素,使用3D变换或 will-change 的元素)会被分到单独的合成层。
6.绘制(Paint):
- 在各个层上填充像素,包括颜色、图片、文字等
7.合成(Compositing):
- 分层之后,在屏幕显示之前,浏览器会将所有层合并。这个过程通常由GPU加速,特别是当使用CSS 3D变换等技术时。
重排(Reflow)和重绘(Repaint)
重排(Reflow):
- 当DOM的变化影响元素的几何属性(如宽度、高度、位置等),浏览器需要重新计算元素的位置和大小。这可能导致整个页面或页面的一部分重新布局。
重绘(Repaint):
- 当元素的外观被改变,但不影响其布局时(如更改颜色、阴影等),浏览器会重新绘制这些元素。
如何避免重排和重绘
1.最小化DOM操作:
使用 DocumentFragment 或隐藏元素进行批量修改,
2.批量修改样式:
- 批量读取CSS样式让浏览器进行合并,然后使用rerequestldleCallback批量修改。即读取和修改分离
3.使用CSS的 transform 和 opacity 进行动画:
- 这些属性不会触发重排和重绘:
4.避免触发同步布局事件:
- 避免频繁读取会触发重排的属性
5.使用绝对定位:
- 对于频繁重排的元素,使用绝对定位。
6.优化CSS选择器:
- 优化CSS选择器,避免过度复杂的选择器。浏览器解析CSS选择器是从右向左的,因此选择器的最右边是关键。
7.避免使用表格布局:
- 因为它可能导致更多的重排。
8.使用 CSS 3D Transform:
- 触发硬件加速,将元素提升到单独的合成层。
9.利用 will-change 属性:
- 提前通知浏览器元素可能的变化,以便优化。
通过这些策略,可以减少和避免重排和重绘,从而提升页面性能。不过,也需要注意不要过度使用某些技术(如3D加速),以免带来其他性能问题。
预告:关注我,下一篇带您了解——CDN的那些事儿、使用及原理