【CSS】层叠上下文和z-index

z-index 的作用范围受"层叠上下文(stacking context)"影响


🔹 1. z-index 的基本作用

  • 控制元素在 同一个层叠上下文(stacking context) 内的堆叠顺序。
  • 值越大,显示层级越靠上。

🔹 2. 什么是层叠上下文(stacking context)

层叠上下文是浏览器渲染时的一个独立空间,z-index 只在同一层叠上下文里比较

一个元素可能会创建新的层叠上下文,比如:

  • 根层叠上下文 :HTML 文档的 <html> 元素天然就是一个。

  • 设置了定位 + z-index 的元素

    • position: relative/absolute/fixed/stickyz-index 值不是 auto
  • 其他能触发层叠上下文的属性(即使没设置 z-index):

    • opacity < 1
    • transform
    • filter
    • perspective
    • clip-path
    • will-change
    • isolation: isolate

🔹 3. 作用范围

  1. 同一层叠上下文内

    • z-index 决定了元素堆叠顺序。
  2. 跨层叠上下文时

    • 不同上下文之间的元素,比较的是上下文容器的层级,而不是容器内部子元素的 z-index。
    • 即:一个子元素 z-index: 9999,也不能盖过外层上下文里 z-index: 10 的兄弟元素。

🔹 4. 举个例子

html 复制代码
<div class="a">
  <div class="b">
    <div class="c">c</div>
  </div>
  <div class="d">d</div>
</div>
css 复制代码
.a {
  position: relative;
  z-index: 1; /* 父容器 A 层级低 */
}

.b {
  position: relative;
  z-index: 9999; /* B 再高也只是 a 内部 */
}

.c {
  position: relative;
  z-index: 99999; /* 在 b 内部最高 */
}

.d {
  position: relative;
  z-index: 2; /* D > A(1),所以 D 在最上面 */
}

👉 结果:

  • .d 会压在 .c 上面,尽管 .c 的 z-index 数字更大。
  • 因为 .c 属于 .a 这个上下文,而 .a 的 z-index = 1,整体比 .d(z-index=2)低。

🔹 5. 总结

  • z-index 只在同一层叠上下文内生效
  • 新的层叠上下文会"隔离"子元素,子元素的 z-index 不能跨越父容器。
  • 想让元素真正覆盖其他内容,要确保它所在的上下文本身层级更高。
相关推荐
xjt_09014 分钟前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js
我是伪码农16 分钟前
Vue 2.3
前端·javascript·vue.js
夜郎king41 分钟前
HTML5 SVG 实现日出日落动画与实时天气可视化
前端·html5·svg 日出日落
夏幻灵2 小时前
HTML5里最常用的十大标签
前端·html·html5
Mr Xu_2 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
未来龙皇小蓝2 小时前
RBAC前端架构-01:项目初始化
前端·架构
程序员agions2 小时前
2026年,微前端终于“死“了
前端·状态模式
万岳科技系统开发2 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
程序员猫哥_2 小时前
HTML 生成网页工具推荐:从手写代码到 AI 自动生成网页的进化路径
前端·人工智能·html
龙飞052 小时前
Systemd -systemctl - journalctl 速查表:服务管理 + 日志排障
linux·运维·前端·chrome·systemctl·journalctl