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 值。

相关推荐
276695829210 分钟前
token1005 算法分析
java·前端·javascript·token·token1005·携程酒店·token算法分析
乆夨(jiuze)11 分钟前
记录一个css,实现下划线内容显示,支持文本多行显示
前端·css
GISer_Jing13 分钟前
前端视频多模态:编解码、传输、渲染全链路详解
前端·人工智能·音视频
恋猫de小郭20 分钟前
Flutter PC 多窗口最新进展,底层原生窗口句柄支持已合并
android·前端·flutter
LIO33 分钟前
Vue3 + Vite + Pinia + TypeScript 项目完整搭建与实战指南
前端·vue.js
kilito_0134 分钟前
vue官网例子 讲解2
前端·javascript·vue.js
蜡台35 分钟前
Vue实现动态路由
前端·javascript·vue.js·router
xiao阿娜的妙妙屋141 分钟前
当AI Agent开始自我进化,我们普通人应该怎么办?
前端
sudo_jin42 分钟前
从“谁调用指向谁”到“手写Bind源码”,彻底搞懂JavaScript的this机制
前端·javascript
小蜜蜂dry42 分钟前
nestjs实战-登录、鉴权(二)
前端·后端·nestjs