CSS display contents 总结

看了很多文章,大家都没讲到重点,且最近浏览器也对 display: contents 做了更新或 bugfix,本文站在 2025 年总结下。

💭 WHAT

display: contents,这是 CSS 中一个很有用的属性值。它可以让一个元素在布局中"消失",但它的子元素仍然会保留在文档流中,就好像这个元素从未存在过一样。这意味着,原本由这个元素生成的框 (包括背景、边框、内边距等)都不会被渲染,但它的子元素仍然会继承它的颜色、字体等属性 ,并且可以参与到上一层级的布局中。这在需要保持 HTML 语义结构的同时或无法修改 HTML 布局时,又想让某些元素在视觉上或布局上消失时非常有用。

🤷‍♂️ WHY

display: contents 是一个用于创建布局的了不起的功能。它允许你将 flex 项或 grid 项的子元素视为它们自己就是 flex(grid) 项。换句话说,你可以将嵌套的 DOM 树"展平 ",以便在一个 flex 或 grid 系统内使用它。如果你无法更改当前布局的 DOM 结构,或者出于任何原因不想更改它,但仍然希望使用 flex(grid) 能力来移动和重新定位元素------不仅适用于 flex(grid) 布局内的兄弟元素,还包括它们的子元素和孙子元素

------ stackoverflow.com/questions/7...

"消失"描述成"flatten"可能更形象,其目的是让内部元素参与外部布局,参与外部布局有什么用?在 flex / grid 布局中,只有直接子元素才会被认为是 flex / grid item,才能被其影响。这就是 display: contents 用武之地。

🍽️ 使用场景

让非直接子元素参与 flex / grid 布局

html 复制代码
<section style="display: flex">
   <div>A</div>
   <div> // <- `display: contents`  让 div 从 UI 上隐藏,让其子元素参与其爷爷 section 的 flex 布局
         <span class="b1">B1</span>
         <span class="b2">B2</span>
    </div>
    <div>C</div>
</section>

详见 stackoverflow.com/questions/7... 第二个回答即可。

无法修改 HTML 布局,比如 Antd 组件

比如想"一键"去除 padding 或 margin border 等 box 属性,可以使用 display: contents,非常方便。

👩‍🦽 无障碍问题

经试验 Chrome 最新版本没有该问题,如果有问题是浏览器实现没有遵循 CSS 规范。故应该放心使用。

https://developer.mozilla.org/en-US/docs/Web/CSS/display#contents

📚 本文参考

相关推荐
青皮桔5 小时前
CSS实现百分比水柱图
前端·css
失落的多巴胺5 小时前
使用deepseek制作“喝什么奶茶”随机抽签小网页
javascript·css·css3·html5
牧杉-惊蛰8 小时前
uniapp微信小程序css中background-image失效问题
css·微信小程序·uni-app
哎呦你好9 小时前
【CSS】Grid 布局基础知识及实例展示
开发语言·前端·css·css3
islandzzzz10 小时前
(第二篇)HMTL+CSS+JS-新手小白循序渐进案例入门
前端·javascript·css·html
晴殇i12 小时前
CSS 迎来重大升级:Chrome 137 支持 if () 条件函数,样式逻辑从此更灵活
前端·css·面试
Hilaku12 小时前
2025年,每个前端都应该了解的CSS选择器:`:has()`, `:is()`, `:where()`
前端·css
sunbyte12 小时前
50天50个小项目 (Vue3 + Tailwindcss V4) ✨ | DragNDrop(拖拽占用组件)
前端·javascript·css·vue.js·vue
旷世奇才李先生13 小时前
CSS 安装使用教程
前端·css
遗憾随她而去.13 小时前
深入理解CSS中的BFC 与IFC , 布局的两大基础概念
前端·css