css中专门用来提升渲染性能、减少重排重绘的属性

一、控制渲染隔离:contain

这是 CSS 性能优化的核心属性content-visibility 底层就是靠它。

css 复制代码
contain: layout paint size style;
contain: content; /* 常用简写 = layout + paint + size */
contain: strict;  /* 最强隔离 */

作用:

  • 告诉浏览器:这个元素内部的变化,不会影响外部页面
  • 浏览器就可以跳过大量计算,只重绘这个小区域
  • 长列表、卡片、弹窗都非常适合用

适用场景:

  • 独立组件、表格行、弹窗、长列表
  • 内部频繁更新,但不影响外部布局

二、GPU 加速与渲染层:will-change

告诉浏览器:这个元素马上要动了,提前准备硬件加速

css 复制代码
will-change: transform, opacity;

作用:

  • 浏览器提前给元素开一个独立图层,交给 GPU 处理
  • 动画、滚动更流畅,不卡帧

注意:

  • 不要滥用,不要全局写
  • 只给真正要动画/滚动的元素用
  • 配合 transform 动画效果最好

三、强制硬件加速:transform / opacity

这两个属性是**唯一不会触发重排(reflow)**的,只会触发合成。

css 复制代码
transform: translateZ(0); /* 经典老方案,强制开层 */

现代推荐:

css 复制代码
transform: translateY(10px);
opacity: 0.9;

优点:

  • 不触发布局(layout)
  • 不触发绘制(paint)
  • 直接 GPU 合成,性能极高

四、控制绘制区域:contain-intrinsic-size

配合 content-visibility 使用,提前告诉浏览器元素尺寸,避免滚动条跳动。

css 复制代码
contain-intrinsic-size: 50px 300px; /* 宽 高 */

作用:

  • 即使内容没渲染,也占好位置
  • 滚动丝滑不抖动

五、减少重绘:backface-visibility

主要用于 3D 动画、轮播图,减少背面绘制。

css 复制代码
backface-visibility: hidden;

六、字体渲染优化

css 复制代码
font-display: swap;
  • 字体未加载完成时,先显示系统字体
  • 避免页面长时间空白(FOIT)
  • 大幅提升首屏性能

七、滚动性能:scroll-behavior + scrollbar-gutter

css 复制代码
scroll-behavior: smooth;
scrollbar-gutter: stable;
  • scrollbar-gutter: stable 防止滚动条出现时页面抖动
  • 避免频繁重排

八、减少重排:position: fixed / sticky

这类元素独立渲染层,滚动时不会触发大量重排。

top/left 动态修改性能高得多。

九、减少样式计算::where() / :is()

优先级更低,减少选择器复杂度,浏览器匹配更快。

css 复制代码
:where(.card .title) {
  color: red;
}

优点:

  • 选择器匹配更快
  • 优先级低,容易覆盖,减少样式冲突

十、图片渲染优化

css 复制代码
image-rendering: crisp-edges;
content-visibility: auto; /* 图片懒渲染 */

现代浏览器还支持:

css 复制代码
img {
  loading: lazy;
  decoding: async;
}

快速记忆(面试版)

真正高频、核心的就这 5 个:

  1. content-visibility: auto ------ 长列表/表格神器
  2. contain: content ------ 隔离渲染,减少重排
  3. will-change ------ 提前 GPU 加速
  4. transform / opacity ------ 高性能动画
  5. contain-intrinsic-size ------ 配合 content-visibility 防抖动

一句话总结

想要优化长表格、长列表、频繁更新的组件:
content-visibility + contain + will-change + transform

这一套组合就是 CSS 性能天花板。

相关推荐
阳火锅27 分钟前
😭测试小姐姐终于不骂我了!这个提BUG神器太香了...
前端·javascript·面试
道友可好1 小时前
AI 是最好的混乱放大器:代码熵管理实战
前端·人工智能·后端
猩猩程序员2 小时前
前端学习 AI Agent 开发
前端
Younglina2 小时前
打了3年羽毛球球才发现:我对自己的装备和胜率一无所知
前端·后端
风骏时光牛马2 小时前
Bash脚本高阶实战与常见报错完整代码案例详解
前端
kartjim2 小时前
我用 AI 一小时写了一个世界杯数据可视化平台|前端 VibeCoding 初体验
前端·程序员·ai编程
lichenyang4532 小时前
从一个 WebView Demo 开始,理解 ASCF 小程序底座到底在做什么
前端
牧艺2 小时前
用 Next.js 搭建 AI Agent 前端编排:从 Plan 到 SSE Trace 的完整实践
前端·agent
行者全栈架构师2 小时前
UniApp集成vk-uview-ui组件库详解:打造高效UI开发体验
前端·vue.js
林希_Rachel_傻希希2 小时前
js里面的proxy理解。以及vue3响应式数据设计底层
前端·javascript·面试