CSS——重排和重绘

1.概念

重排(Reflow)与重绘(Repaint)是浏览器渲染管线中的两个关键环节,直接决定页面性能。重排一定触发重绘,重绘不一定触发重排。

1.2 重排(Reflow)

重排 = Layout(布局) 阶段重新计算元素的几何信息(位置、大小)。触发条件:

典型代码 说明
el.style.width = '200px' 改变宽度
el.style.display = 'none' 隐藏元素
el.classList.add('col-3') 类名改变布局
dom.offsetHeight / getComputedStyle 强制同步刷新
字体大小、内容变化、图片加载完成 都会让浏览器重新算盒子
特点
  • 作用范围:从当前元素向上找定位祖先,向下找所有子节点,可能整页一起算。

  • 耗时:与 DOM 大小成正比,移动端尤其明显。

  • 阻塞后续 JS 执行(渲染线程和主线程互斥)。

1.3 重绘(Repaint)

重绘 = Paint 阶段重新绘制像素(颜色、阴影、文字等)。触发条件:

典型代码 说明
el.style.color = 'red' 改文字颜色
el.style.boxShadow = '...' 改阴影
el.style.visibility = 'hidden' visibility 隐藏仍占位,不影响布局
特点
  • 跳过 Layout 阶段,比重排便宜(性能:重排 > 重绘),但仍需重新绘制像素。

  • 若元素在独立合成层 (will-change、transform、opacity),可直接 GPU 合成,连 Paint(绘制) 都跳过

2.扩展

2.1 translate去改变位置------减少重排

translate代替传统定位方式(top、left、right、bottom),它操作的是合成层而不是布局层,所以浏览器不会因位置改变而重新布局。

新版本浏览器会自动将元素提升为独立合成层,而旧版本需要will-change: transform; 属性
javascript 复制代码
// 手动提升为合成层属性
will-change: transform;   /* 最标准 */
transform: translateZ(0); /* 传统 hack */
相关推荐
Laurence5 分钟前
从零到一构建 C++ 项目(IDE / 命令行双轨实现)
前端·c++·ide
雯0609~15 分钟前
hiprint-官网vue完整版本+实现客户端配置+可实现直接打印(在html版本增加了条形码、二维码拖拽等)
前端·javascript·vue.js
GISer_Jing17 分钟前
构建高性能Markdown引擎开发计划
前端·aigc·ai编程
CHU72903535 分钟前
生鲜商城小程序前端功能版块:适配生鲜采购核心需求
前端·小程序
huangyiyi666661 小时前
Vue + TS 项目文件结构
前端·javascript·vue.js
0思必得01 小时前
[Web自动化] Selenium处理Cookie
前端·爬虫·python·selenium·自动化
徐同保1 小时前
react-markdown使用
前端·react.js·前端框架
2601_949857431 小时前
Flutter for OpenHarmony Web开发助手App实战:CSS参考
前端·css·flutter
无法长大1 小时前
如何判断项目需不需要用、能不能用Tailwind CSS
前端·css·vue.js·elementui·vue3·tailwind css
橙露1 小时前
移动端前端适配:Rem、VW/VH 与媒体查询的综合应用指南
前端·媒体