CSS中的"后"发制人

问题

在Web开发中,经常遇到元素重叠的情况。比如在grid布局中,当两个元素占据同一块空间,为什么总是一个显示在前面,另一个被遮挡?

答案很简单,因为它遵循一个核心原则:在默认情况下,后出现的元素会覆盖先出现的元素。

想象 HTML 文档是一条时间线。浏览器从上到下逐行解析代码。当浏览器遇到一个新元素时,它会把它放到页面上。

  • HTML 顺序 :如果先写了 <main>,再写 <footer>,那么在浏览器眼里,<footer> 就是后来的。
  • 默认堆叠 :在没有其他规则干预的情况下,后来的 <footer> 自然会显示在先来的 <main> 上方。

这个"先来后到"的原则就是 文档流(Document Flow) 的一个基本体现,它决定了所有元素在三维空间中的默认堆叠顺序。

示例

html 复制代码
<body>
  <header>
    <h1>Hello</h1>
  </header>
  <main>
    <p>main</p>
  </main>
  <footer>
    <p>footer</p>
  </footer>
</body>
</html>
<style>
body{
  display:grid;
  grid-template:1fr auto 1fr/1fr auto;
}
header{
  grid-row:1;
  grid-column:1/3;
}
main{
  grid-row:2;
  grid-column:2;
}
footer{
  grid-row:2;
  grid-column:2;
}
</style>

显示效果如下

可见footer遮盖了main

如何控制元素的堆叠?

若想改变这种默认的"后发制人"规则时,需要使用 CSS 的 z-index 属性。

  • z-index :元素的"堆叠层级",数值越高,元素就越靠前。

给需要显示在前面的元素设置一个更高的 z-index 值。

相关推荐
donecoding1 天前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
风骏时光牛马1 天前
Raku正则匹配与数据批量处理实操案例
前端
nbwenren1 天前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Lee川1 天前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端
jinanwuhuaguo1 天前
(第二十九篇)OpenClaw 实时与具身的跃迁——从异步孤岛到数字世界的“原住民”
前端·网络·人工智能·重构·openclaw
广州华水科技1 天前
深度测评2026年单北斗GNSS位移监测系统推荐,与高口碑变形监测设备一同引领行业新风尚
前端
Alice-YUE1 天前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
是上好佳佳佳呀1 天前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记
CDN3601 天前
排查实录:网站偶发502/504错误?360CDN回源超时配置与日志分析技巧
前端·数据库