专业编程教程与实战项目分享平台

网站首页 > 技术文章 正文

前端每日一读,大厂面试无忧:网络与安全—浏览器渲染流程、重排

ins518 2025-06-12 13:10:32 技术文章 9 ℃ 0 评论

哈咯~ 大家好~ 又是美好的一天,前端小菜鸟上线啦,为大家带来今天的“前端每日一读,大厂面试无忧”——浏览器渲染流程,重排、重绘,以及如何避免重排和重绘

浏览器的渲染流程是一个包含多个步骤的复杂过程,主要涉及以下环节

浏览器渲染流程

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的 transformopacity 进行动画:

  • 这些属性不会触发重排和重绘:

4.避免触发同步布局事件:

  • 避免频繁读取会触发重排的属性

5.使用绝对定位:

  • 对于频繁重排的元素,使用绝对定位。

6.优化CSS选择器:

  • 优化CSS选择器,避免过度复杂的选择器。浏览器解析CSS选择器是从右向左的,因此选择器的最右边是关键。

7.避免使用表格布局:

  • 因为它可能导致更多的重排。

8.使用 CSS 3D Transform:

  • 触发硬件加速,将元素提升到单独的合成层。

9.利用 will-change 属性:

  • 提前通知浏览器元素可能的变化,以便优化。

通过这些策略,可以减少和避免重排和重绘,从而提升页面性能。不过,也需要注意不要过度使用某些技术(如3D加速),以免带来其他性能问题。

预告:关注我,下一篇带您了解——CDN的那些事儿、使用及原理

Tags:

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表