z-index用于控制定位元素的堆叠顺序,数值越大越靠前;其作用受堆叠上下文限制,父元素创建堆叠上下文后子元素层级无法超出该范围;常见应用如模态框、下拉菜单等需设置较高z-index以确保显示在顶层。

在css中,z-index 用来控制元素的堆叠顺序,也就是哪个元素显示在前面、哪个在后面。它只对定位元素(即 position 值为 relative、absolute、fixed 或 sticky 的元素)生效。
z-index的基本用法
给一个定位元素设置 z-index,数值越大,越靠近用户,会覆盖 z-index 较小的元素。
例如:
红色块
蓝色块
这里蓝色块的 z-index 更大,所以会盖住红色块。
理解堆叠上下文(Stacking Context)
z-index 不是全局比较的,它的作用范围受“堆叠上下文”限制。一旦某个元素创建了新的堆叠上下文,它的子元素就只能在这个范围内比较层级。
立即学习“前端免费学习笔记(深入)”;
以下情况会创建新的堆叠上下文:
- 根元素(html)
- position 值为非 Static 且 z-index 不为 auto 的元素
- opacity 小于 1 的元素
- transform 不为 none 的元素
- Filter 不为 none 的元素
- will-change 设置了影响堆叠的属性
这意味着:即使子元素 z-index 设为 9999,如果父容器的堆叠层级低,它也无法超出其他堆叠上下文中的元素。
常见使用技巧与注意事项
合理使用 z-index 能避免布局混乱。以下是实用建议:
- 不要滥用高数值如 99999,建议分层管理,比如导航用 1000,弹窗用 2000,提示用 3000
- 确保父元素没有意外创建堆叠上下文,导致子元素无法“浮”出来
- 使用 z-index 时一定要配合 position 属性,否则无效
- 调试时可用浏览器开发者工具查看元素的渲染层级
实际应用场景举例
典型用途包括:
- 模态框(Modal):设为 high z-index(如 1000),确保遮罩和弹窗在最上层
- 下拉菜单:设置 z-index 高于页面内容,避免被其他块遮挡
- 轮播图切换:通过 z-index 控制当前页在顶层
基本上就这些。掌握 z-index 的关键在于理解“定位 + 堆叠上下文”的机制,不复杂但容易忽略细节。


