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 性能天花板。

相关推荐
Hello--_--World5 分钟前
ES15:Object.groupBy() 和 Map.groupBy()、Promise.withResolvers() 相关知识点
开发语言·前端·javascript
Cache技术分享14 分钟前
386. Java IO API - 监控目录变化
前端·后端
Hooray21 分钟前
管理后台框架 AI 时代的版本答案,Fantastic-admin 6.0 它来了!
前端·前端框架·ai编程
2501_9136800029 分钟前
Vue3项目快速接入AI助手的终极方案 - 让你的应用智能升级
前端·vue.js·人工智能·ai·vue·开源软件
开开心心_Every30 分钟前
动图制作工具,拆分转视频动态照离线免费
运维·前端·人工智能·edge·pdf·散列表·启发式算法
饭后一颗花生米39 分钟前
2026 前端实战:AI 驱动下的性能优化与工程化升级
前端·人工智能·性能优化
YJlio1 小时前
4月14日热点新闻解读:从金融数据到平台治理,一文看懂今天最值得关注的6个信号
java·前端·人工智能·金融·eclipse·电脑·eixv3
xjf77111 小时前
AI重构前端项目指南
前端·ai·重构·编程
踩着两条虫1 小时前
VTJ:应用场景展示
前端·vue.js·架构
恋恋风尘hhh1 小时前
Web 前端安全机制分析:以 Webpack 打包混淆为例
前端·安全·webpack