写点什么

CSS 层叠上下文(Stacking Context)

  • 2021-01-19
  • 本文字数:2400 字

    阅读完需:约 8 分钟

CSS 层叠上下文(Stacking Context)

在网页制作的过程中,元素与元素之间的位置关系,在坐标轴上一般可体现为 X 轴、Y 轴和 Z 轴。对于 X 轴和 Y 轴的定位大多数开发都能比较直观的搞清楚,而 Z 轴 则相对较为模糊,或者说不能全面的理解 Z 轴的显示逻辑。


大多数人都知道可以使用 position 属性配合 z-index 属性解决元素的 Z 轴显示问题,对于更深层次的原理却不太了解。本文主要介绍了层叠上下文、层叠等级、层叠顺序等概念。目的就是为了理清元素的 Z 轴显示顺序的内部逻辑。


一、现象

Z 轴上的显示顺序

// 穿透父级容器的 z-index  <!-- 100 * 100 的深蓝色 Block -->  <div class="block blue" style="position: relative; z-index: auto;">    <!-- 50 * 50 的红色 Block -->    <div class="small red" style="position: relative; z-index: -1;"></div>  </div>
复制代码



// 不能穿透父级容器的 z-index <!-- 100 * 100 的深蓝色 Block -->  <div class="block blue" style="position: relative; z-index: 0;">    <!-- 50 * 50 的红色 Block -->    <div class="small red" style="position: relative; z-index: -1;"></div>  </div>
复制代码



两段代码基本一样,只有在深蓝色盒子处有个 z-index 不同。当父级容器的 z-index 为 auto 的时候,红色盒子穿过了父级容器出现在了父级容器的背后(被父级容器遮挡住)。当父级容器的 z-index 为 0 的时候,红色盒子无法穿过父级容器。

元素 Z 轴对比


// 元素 Z 轴对比  <!-- 100 * 100 的深蓝色盒子 -->  <div class="block blue">    <div style="position:relative;z-index:auto;">      <!-- 50 * 50 的红色盒子 -->      <div class="small red" style="position:absolute; z-index:2;"></div>    </div>    <div style="position:relative;z-index:auto;">      <!-- 50 * 50 的灰色盒子 -->      <div class="small yellow" style="position:absolute; z-index:1; top: 10px;"></div>    </div></div>
复制代码



// 元素 Z 轴对比  <!-- 100 * 100 的深蓝色盒子 -->  <div class="block blue">    <div style="position:relative;z-index:0;">      <!-- 50 * 50 的红色盒子 -->      <div class="small red" style="position:absolute; z-index:2;"></div>    </div>    <div style="position:relative;z-index:0;">      <!-- 50 * 50 的灰色盒子 -->      <div class="small yellow" style="position:absolute; z-index:1; top: 10px;"></div>    </div>  </div>
复制代码



同样的,以上两段代码基本一样,都是有 3 层的 DIV 盒子。最外层是一个深蓝色盒子,中间一层容器盒子,最下面一层红色及灰色盒子。不同之处在于中间这层容器盒子的 z-index 由 auto 变成了 0。最底下的红色及灰色盒子的 Z 轴层级比较的结果就截然不同。


由以上两个例子我们可以发现,当 z-index 为数值并且生效的时候,容器会发生一种变化,会使得容器内的子组件无法穿过容器本身,并且子组件的层级由父组件决定。这种变化后的容器元素我们称之为层叠上下文。


二、特性


层叠上下文有几个特性


层叠上下文可以嵌套,内部层叠上下文及其所有子元素均受制于外部的层叠上下文。


这个好理解,可以参考例子 2 。当第二层的容器盒子升级为层叠上下文时,红色盒子及灰色盒子的 Z 轴层级受制于第二层的容器盒子。


每个层叠上下文和兄弟元素独立,也就是当进行层叠变化或渲染的时候,只需要考虑后代元素。


这一条在性能优化上可以用的上。在更新 DOM 元素的时候考虑上层叠上下文可以使得站点性能表现更加优异。


层叠上下文未指定 z-index 时,其层叠等级与 z-index : 0 相同, 要比普通元素高。指定 z-index 时按照层叠规则来。


这条专门指的由 CSS3 属性创建出来的层叠上下文,其本身未指定 z-index。其层叠等级应该是 z-index: 0。


三、创建


层叠上下文大体上可分为三种创建方式


1. 页面根元素,称为根层叠上下文 

2. z-index 值为数值的定位元素的传统层叠上下文

3. 其他 CSS3 属性(详情可动手实验了解)

  • z-index 值不为auto 的flex 项(父元素display:flex | inline-flex )

  • 元素的 opacity 值不是 1 

  • 元素的 transform 值不是 none

  • 其他

  • 元素的 filter 值不是 none


注意:

1、z-index: auto 和 z-index: 0 在层叠等级上属于同一级。但是 z-index: 0 就是符合这一条“z-index 为数值”会使得元素升级为层叠上下文。

2、 IE6,7 有个不合常理的地方,就是当元素的 z-index 为 auto 的时候,该元素也升级为创建层叠上下文。这就是为什么在过去 IE6/IE7 的 z-index 一直是个老大难的原因。


四、两个概念:层叠顺序、层叠等级


在说层叠规则之前两个概念需要大家了解一下,这有利于我们在日常交流中探讨相关的问题。


  • 层叠顺序( Stacking Order ),这个其实就是很字面的意思,它表示元素发生层叠时按照特定的顺序规则在 Z 轴上垂直显示顺序。

  • 层叠等级( Stacking Level ),这个很好理解了。层叠等级就是个描述元素层叠顺序的一个名词,它决定了同一个层叠上下文中元素在 Z 轴上的显示顺序。举个例子:A 元素与 B 元素重叠之后,A 元素在 B 元素上面。那么我们就可以直接说 A 元素的层叠等级大于 B 元素的层叠等级。


五、层叠规则


当元素互相层叠的时候,显示规则如下。


  • 当互相层叠的元素都是层叠上下文元素,即明确的有 z-index 值的时候(没有明确的 z-index 值的层叠上下文也就是 CSS3 创建的层叠上下文 z-index 值为 0 )直接比较 z-index 的值,值大的处在值小的元素的上方。

  • 当元素处于同一层叠上下文内时可按照如下规则进行层叠判断。



  • 当元素的层叠等级一致、层叠顺序也相同的时候,在 DOM 流中处于后面的元素会覆盖前面的元素。



头图:Unsplash

作者:简名

原文:https://mp.weixin.qq.com/s/WFZm2eRf-aRImurnoVFxqw

原文:CSS 层叠上下文(Stacking Context)

来源:政采云前端团队 - 微信公众号 [ID:Zoo-Team]

转载:著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

2021-01-19 23:451786

评论

发布
暂无评论
发现更多内容

体育场馆LED屏解决方案

Dylan

LED显示屏 户外LED显示屏 led显示屏厂家 户内led显示屏 体育

Solana 开发者拟将区块计算单位上限从 6000 万提升至 1 亿,带来繁荣的链上生态

PowerVerse

腾讯云TencentOS提交Swap Table补丁系列 Linux内核内存交换性能提升20%~30%

极客天地

传统公关已式微?企业出海品牌维护要靠实时舆情监控

沃观Wovision

出海企业 海外舆情 沃观Wovision 舆情监测系统

【新模型速递】PAI-Model Gallery云上一键部署Qwen3-Coder模型

阿里云大数据AI技术

人工智能 大数据 开源 大模型 Qwen3-Coder

BetterYeah“AI生产力奇妙屋”新品首秀,@WAIC H1-B1135

BetterYeah AI

AI Agent

5000字谈普通人如何用AI利益最大化

阿星AI工作室

AI 产品经理 小白 工具集 AIGC

免费的 AI 数据分析神器!3 分钟、0 代码构建 AI 问数智能体

极客天地

KaiwuDB 2.1.0 单节点裸机部署

KaiwuDB

MyEMS开源能源管理系统核心代码解读020

开源能源管理系统

开源 开源能源管理系统 代码解读 能源管理系统

Cisco vManage漏洞分析:从SSRF到Root权限的完整攻击链

qife122

网络安全 SD-WAN

我的代码背叛了我?为什么 a=1, b=2,最后x和y都等于0?

poemyang

并发编程 volatile 可见性 Java并发编程

KWDB一键部署全攻略

KaiwuDB

GPU服务器与PC 集群:科技算力双子星

GPU算力

异构计算 异构计算架构 GPU 集群 #PC集群 PC 农场

精彩瞬间:阿里云 KubeCon China 2025 之行回顾!

阿里巴巴云原生

阿里云 云原生 KubeCON

NocoBase 本周更新汇总:优化及缺陷修复

NocoBase

开源 低代码 零代码 无代码 版本更新

中国重汽亲人服务:以全球培训中心为支点,撬动服务升级新格局!

科技热闻

一文看懂:用UI设计工具变量系统低成本完成App适老化改造

职场工具箱

产品经理 产品设计 开发 变量 ui设计

懂车帝智驾评测,带来了审慎还是武断?

脑洞汽车

AI

Infuse Pro for Mac 超强全能视频播放器

晨光熹微

TEM on 腾讯云安装 + 试用指南

TiDB 社区干货传送门

MyEMS开源能源管理系统核心代码解读019

开源能源管理系统

开源 开源能源管理系统 代码解读 能源管理系统

AI 应用开发的陷阱:MCP 的致命问题

电子尖叫食人鱼

人工智能 大数据

经过全面测评之后,我们选出了四款Mac电脑最值得推荐的解压软件

阿拉灯神丁

Mac软件 mac解压缩软件 BetterZip 5

MyEMS开源能源管理系统核心代码解读018

开源能源管理系统

开源 开源能源管理系统 代码解读 能源管理系统

UniApp + ThinkPHP 开黑游戏陪玩小程序(老板评价+订单系统)

DUOKE七七

uni-app thinkphp6

2025杭州国际智能科技产业博览会(世亚智博会)

AIOTE智博会

智博会 人工智能展 世亚智博会 智能科技展 杭州智博会

Mysql查询语句执行流程?更新语句执行流程?

不在线第一只蜗牛

MySQL

收藏!国内120+AI Agent开发/构建平台大盘点(上):互联网、云计算、AI、传统软件厂商推出的智能体平台

王吉伟频道

智能体 AI Agent Agentic AI 智能体平台 Agent开发平台

Wipr for Mac 广告拦截与隐私保护工具

晨光熹微

电脑下载速度很慢怎么解决 提高电脑下载速度的软件推荐

阿拉灯神丁

视频下载器 idm下载 下载工具

CSS 层叠上下文(Stacking Context)_语言 & 开发_政采云前端团队_InfoQ精选文章