网站首页 > 技术文章 正文
哈咯~ 大家好~ 又是美好的一天,前端小菜鸟上线啦,为大家带来今天的“前端每日一读,大厂面试无忧”——浏览器渲染流程,重排、重绘,以及如何避免重排和重绘
浏览器的渲染流程是一个包含多个步骤的复杂过程,主要涉及以下环节
浏览器渲染流程
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 记一笔前端需要关注的安全知识 前端安全规范
你 发表评论:
欢迎- 最近发表
-
- Three.js vs Unity:工业可视化为何选择Web方案?
- 一款全新Redis UI可视化管理工具,支持WebUI和桌面——P3X Redis UI
- 时间线可视化实战:三款AI工具实测,手把手教你制作人生轨迹图
- 【推荐】一款可视化在线 Web 定时任务管理平台,支持秒级任务设置
- 重磅更新!FastDatasets 推出可视化 Web 界面
- 模具设计之UG钣金实例教程(3)_ug钣金基础教程
- 前端基于 RBAC 模型的权限管理实现
- 别再把JWT存在localStorage里了!2025年前端鉴权新思路
- 模具设计之曲面造型中不圆润的曲面如何处理技巧
- 9个专业级别的CSS技巧区分了解和精通的鸿沟
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- oracle面试 (55)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)