CSS 局限-contain

CSS 局限

CSS 局限规范的目标在于通过允许浏览器从页面的其余部分中隔离出页面子树而改善性能。若浏览器知道页面的某一部分为独立的,则可优化渲染并改善性能。

此外,此规范允许开发者标示元素究竟是否应当渲染其内容,以及在屏外时是否应当渲染其内容。由此允许用户代理在恰当的时候在元素上应用局限,并有望将布局和渲染推迟至需要时再进行。

此规范定义了 CSS 属性 contain 和 content-visibility。

contain

CSS 属性 contain 标示了元素及其内容尽可能独立于文档树的其余部分。局限使 DOM 的一部分得以被隔离,且通过将布局、样式、绘制、尺寸或其任意组合的计算限制于 DOM 子树而非整个页面使性能受益。

none

元素照常渲染,不应用局限。如上图。

layout

从页面的其余部分中隔离出元素的内部布局。此值意味着元素外的任意内容和元素内部布局互不影响。如上图。

paint

元素后代不在元素边界外显示。若包含盒在屏外,则浏览器无需绘制其被局限的元素------这些元素因为完全局限于此盒故必定也在屏外。若后代元素溢出包含元素的边界,则此后代元素将被裁剪至包含元素的边框盒。如上图。

总结一下,contain 属性是一个用于优化性能的 CSS 属性,可以告诉浏览器某个元素是否独立于其他元素进行渲染。通过使用不同的值,我们可以指定元素的渲染上下文,从而帮助浏览器更好地进行优化。

相关推荐
贼爱学习的小黄16 分钟前
NC BIP参照开发
java·前端·nc
小江的记录本20 分钟前
【MyBatis-Plus】MyBatis-Plus的核心特性、条件构造器、分页插件、乐观锁插件
java·前端·spring boot·后端·sql·tomcat·mybatis
光影少年25 分钟前
如何进行前端性能优化?
前端·性能优化
Dxy123931021632 分钟前
js如何把字符串转数字
开发语言·前端·javascript
爱写bug的野原新之助40 分钟前
爬虫之补环境:加载原型链
前端·javascript·爬虫
陈广亮1 小时前
工具指南7-Unix时间戳转换工具
前端
NGBQ121381 小时前
Adobe-Premiere-Pro-2026-26.0.2.2-m0nkrus 全解析:专业视频编辑软件深度指南
前端·adobe·音视频
北城笑笑1 小时前
Chrome:Paused in debugger 的踩坑实录:问题排查全过程与终极解决方案( 在调试器中暂停 )
前端·chrome
haorooms1 小时前
Promise.try () 完全指南
前端·javascript
kyriewen1 小时前
闭包:那个“赖着不走”的家伙,到底有什么用?
前端·javascript·ecmascript 6