网站首页 > 技术文章 正文
哈咯~ 大家好~ 又是美好的一天,前端小菜鸟上线啦,为大家带来今天的“前端每日一读,大厂面试无忧”——浏览器渲染流程,重排、重绘,以及如何避免重排和重绘
浏览器的渲染流程是一个包含多个步骤的复杂过程,主要涉及以下环节
浏览器渲染流程
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的那些事儿、使用及原理
猜你喜欢
- 2025-06-12 75.4K Star!RustDesk:开源远程桌面工具,安全、快速、还免费!
- 2025-06-12 RTO前端LEL在线监测仪FTA检测,让VOC废气治理更安全
- 2025-06-12 注册安全工程师安全生产技术练习题10(每日十题)
- 2025-06-12 RTO前端易燃气体LEL在线分析仪,RTO安全运行的保障
- 2025-06-12 灿芯股份(688691.SH):基于40nmEFlash的车规双核锁步MCU平台已完成功能安全相关前端和DFT部分的主体设计
- 2025-06-12 JS严格模式:更安全、更高效的代码实践
- 2025-06-12 企业安全生产管理流于形式怎么办?他们这样抓前端治未病
- 2024-09-30 web前端安全规范 web前端网络安全
- 2024-09-30 浅谈 Web 安全 web安全有哪些方面
- 2024-09-30 记一笔前端需要关注的安全知识 前端安全规范
你 发表评论:
欢迎- 532℃Oracle分析函数之Lag和Lead()使用
- 531℃几个Oracle空值处理函数 oracle处理null值的函数
- 529℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 519℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 513℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 504℃【数据统计分析】详解Oracle分组函数之CUBE
- 484℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 483℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端富文本编辑器 (47)
- 前端路由 (61)
- 前端数组 (73)
- 前端排序 (47)
- 前端密码加密 (47)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)