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

相关推荐
a1117761 小时前
医院挂号预约系统(开源 Fastapi+vue2)
前端·vue.js·python·html5·fastapi
0思必得01 小时前
[Web自动化] Selenium处理iframe和frame
前端·爬虫·python·selenium·自动化·web自动化
行走的陀螺仪3 小时前
uni-app + Vue3编辑页/新增页面给列表页传参
前端·vue.js·uni-app
We་ct4 小时前
LeetCode 205. 同构字符串:解题思路+代码优化全解析
前端·算法·leetcode·typescript
2301_812731414 小时前
CSS3笔记
前端·笔记·css3
ziblog5 小时前
CSS3白云飘动动画特效
前端·css·css3
越努力越幸运5085 小时前
CSS3学习之网格布局grid
前端·学习·css3
半斤鸡胗5 小时前
css3基础
前端·css
ziblog5 小时前
CSS3创意精美页面过渡动画效果
前端·css·css3
akangznl5 小时前
第四章 初识css3
前端·css·css3·html5