【CSS in Depth 2 精译_041】6.4 CSS 中的堆叠上下文与 z-index(上)

news2024/9/27 23:55:30

当前内容所在位置(可进入专栏查看其他译好的章节内容)

  • 第一章 层叠、优先级与继承(已完结)
  • 第二章 相对单位(已完结)
  • 第三章 文档流与盒模型(已完结)
  • 第四章 Flexbox 布局(已完结)
  • 第五章 网格布局(已完结)
  • 【第六章 定位与堆叠上下文】 ✔️
    • 6.1 固定定位
      • 6.1.1 创建一个固定定位的模态对话框
      • 6.1.2 在模态对话框打开时防止屏幕滚动
      • 6.1.3 控制定位元素的大小
    • 6.2 绝对定位
      • 6.2.1 关闭按钮的绝对定位
      • 6.2.2 伪元素的定位问题
    • 6.3 相对定位
      • 6.3.1 创建下拉菜单(上)
      • 6.3.2 创建 CSS 三角形(下)
    • 6.4 堆叠上下文与 z-index ✔️
      • 6.4.1 理解渲染过程与堆叠顺序(上) ✔️
      • 6.4.2 用 z-index 控制堆叠顺序(上) ✔️
      • 6.4.3 深入理解堆叠上下文(下)(精译中 ⏳)

文章目录

    • 6.4 堆叠上下文与 z-index(Stacking contexts and z-index)
      • 6.4.1 理解渲染过程与堆叠顺序 Understanding the rendering process and stacking order
      • 6.4.2 用 z-index 控制堆叠顺序 Manipulating stacking order with z-index

《CSS in Depth》新版封面

《CSS in Depth》新版封面

译者按
前面利用 CSS 的定位技术相继实现了模态对话框和下拉菜单的效果,这一节将重点处理二者在页面渲染时出现的意外堆叠问题。本节内容非常重要,由于篇幅较长,特地分为上篇和下篇进行介绍。本篇为上篇,先讲讲堆叠问题的具体处理。下一篇再深入原理,彻底弄清堆叠上下文的核心概念及行为模式。其实阻碍前端开发人员进阶中高级水平的,往往就是这些平时就掌握得模棱两可的核心概念,即便工作中遇到过,事后也鲜有及时复盘与梳理。让我们跟随作者的脚步,一起持续深耕,潜心积累!

6.4 堆叠上下文与 z-index(Stacking contexts and z-index)

定位技术(Positioning)固然实用,但更重要的是弄明白它会带来什么样的意外情况。一个元素自从脱离文档流后,之前由文档流负责的工作从此也将由您来全面接管。

比如,要时刻确保该元素不会意外跑到浏览器视口(viewport)的外面,让用户找不着它;其次,必须保证该元素不会意外挡住页面上的重要内容。

最后还要考虑元素堆叠(stacking)方面的问题。在同一页面定位多个元素时,很可能会遇到两个不同的定位元素发生重叠的情况,并且偶尔还会发现它们并没有乖乖按照我们预想的方式进行重叠。其实本章的示例已经有意设置了这样的问题场景,以便进一步演示该如何处理。

根据之前示例页面的设计需求,点击页面顶部的注册按钮(即 “Sign up” 字样的按钮)就能打开一个模态对话框。要是把下拉菜单相关的 HTML 标记放到模态框的源码后面,最终效果就会如下图 6.10 所示,下拉菜单意外挡在了模态对话框的前面:

图 6.10 模态框错误地出现在下拉菜单的后面

图 6.10 模态框错误地出现在下拉菜单的后面

解决这个问题有很多种方案。在此之前,有必要先了解一下浏览器确定元素堆叠顺序的基本原理。为此,需要进一步考察一个页面在浏览器中的渲染过程。

6.4.1 理解渲染过程与堆叠顺序 Understanding the rendering process and stacking order

在浏览器将 HTML 解析为 DOM 时,它还会同步创建一个新的树形结构,称为 渲染树(render tree。该渲染树不仅体现了每个元素的视觉样式和位置,同时也决定着浏览器 绘制(paint 这些元素的顺序。该顺序 极其重要:一旦发生重叠,后绘制的元素就会出现在先绘制的元素上。

通常情况下(即使用 CSS 定位前),该绘制顺序由元素在 HTML 中出现的源码顺序决定。以如下 HTML 标记的这三个元素为例:

<div>one</div>
<div>two</div>
<div>three</div>

它们相互间的堆叠行为将如图 6.11 所示。这里使用了负的外边距来让元素重叠,但并没有设置任何定位。可以看到,源码位置靠后的元素绘制在了位置靠前的元素上:

图 6.11 正常情况下三个元素的堆叠效果

图 6.11 正常情况下三个元素的堆叠效果

而设置定位后,情况就不同了。浏览器会优先绘制所有未被定位的元素(non-positioned elements),然后再绘制已定位的元素。默认情况下,已定位的所有元素都会出现在尚未定位的元素前面(to the front)。如图 6.12 所示,给前两个元素加上 position: relative 后,它们就绘制到前面去了,覆盖了静态定位下的第三个元素,尽管元素在 HTML 中的源码顺序并未改变。

注意,在定位的这两个元素中,第二个元素还是绘制在了第一个元素的前面。虽然定位元素都被放到了前面,但它们之间基于源码的重叠关系仍旧不变。

图 6.12 已定位的元素绘制在了静态元素的前面

图 6.12 已定位的元素绘制在了静态元素的前面

也就是说,此时的示例页中,模态框和下拉菜单都会出现在静态内容之前(符合预期),但源码里后出现的元素还是会绘制到先出现的元素前面。要解决这个问题,有一种方案是将 <div class="modal"> 及其所有内容全部移动到下拉菜单 HTML 源码的后面。

通常情况下,模态框都会放到网页内容的最后,即 </body> 关闭标签的前面;大多数构建模态框的 JavaScript 库也会自动照这样处理。因为模态框用的是固定定位,所以无论其 HTML 标记在哪儿,最终都会被定位到屏幕正中。

移动源码位置这招对于固定定位元素来讲倒是没啥影响,但要是换作相对定位元素或者绝对定位元素,这招就失灵了。因为相对定位元素依赖于文档流,而绝对定位元素依赖于它最近的那个祖先定位元素(译注:即 containing block 包含块。详见 6.2 节内容)。这就需要我们另辟蹊径来控制此类元素的堆叠行为。于是就轮到 CSS 中的 z-index 属性闪亮登场了!

6.4.2 用 z-index 控制堆叠顺序 Manipulating stacking order with z-index

z-index 属性的值可以为任意整数(正负数均可)。这里的 z 表示的是笛卡尔 X-Y-Z 坐标系(译注:即三维直角坐标系)里的深度方向。z-index 值较高的元素会出现在该值较低的元素的前面。属性值为负数的元素则会出现在静态元素后面。

使用 z-index 属性便是解决页面堆叠问题的第二种方案。该方案不要求修改 HTML 的结构,只需令元素 modal-backdropz-index 值为 1、且元素 modal-bodyz-index 值为 2 即可(这样就确保了模态框的主体部分位于蒙层的前方)。根据代码清单 6.11 更新本地样式表:

代码清单 6.11 给模态框加上 z-index 使其出现在下拉菜单前面

.modal-backdrop {
  position: fixed;
  inset: 0;
  background-color: rgba(0 0 0 / 0.5);
  z-index: 1;  /* 将模态框的蒙层置于未设置 z-index 的元素前方 */
}

.modal-body {
  position: fixed;
  inset-block: 3em;
  inset-inline: 20%;
  padding: 2em 3em;
  background-color: white;
  overflow: auto;
  z-index: 2;  /* 将模态框主体提到蒙层的前方 */
}

z-index 看似简单,使用时却有两个小陷阱(gotchas)务必要当心:一是 z-index 只对定位元素生效,无法控制静态元素的堆叠顺序;其二,一旦给定位元素设置了 z-index,就必然会牵涉到另一个核心概念,称之为 堆叠上下文(stacking context

(上篇完。由于篇幅较长,堆叠上下文的核心概念及其作用原理将在下篇中重点介绍,敬请关注)



关于《CSS in Depth》(中译本书名《深入解析 CSS》)

第 1 版第 2 版
读者评分原版:4.7(亚马逊);中文版:9.3(豆瓣)原版:5.0(亚马逊);中文版:暂无,待出版
出版时间原版:2018 年 3 月;中文版:2020 年 4 月原版:2024 年 7 月;中文版:暂无,待出版
原价原版:$44.99;中文版:¥139.00原版:$59.99;中文版:暂无,待出版
现价原版:$36.49;中文版:¥52.54 起步原版:$52.09;中文版:暂无,待出版
原版国内预订起步价 ¥461.00起步价 ¥750.00

本专栏为该书第 2 版高分译文专栏,全网首发,精译精校,持续更新,计划今年内完成全书翻译,敬请期待!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2171543.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

AT89C51 利用SBIT寻址,并且在内存中实现伪动态密码的混淆

前置发现 && 分析 char bdata DB[2]; //char sbit x bdata DB[0]^7; //取内存地址数组[0]地址的的七位 这样我们可以对数组DB中索引0的位置进行修改… 例如,将密码A映射到真实密码C,这样做的好处是你的程序被逆向分析的时候,攻击者无法真正知道密码到底是什么…因为…

C语言-线程

一,线程的概念 1,线程的定义 在 C 语言中&#xff0c;线程是程序执行的最小单位&#xff0c;它是进程中的一个实体&#xff0c;是被系统独立调度和分派的基本单位。 2、线程的特点 轻型实体&#xff1a;线程是一个轻型实体&#xff0c;它只拥有必不可少的资源&#xff0c;如程…

学生党有福了!分享5个免费的AI论文生成工具

学生党在学术写作方面常常面临时间紧迫和写作能力不足的问题。幸运的是&#xff0c;随着人工智能技术的发展&#xff0c;市面上出现了许多免费的AI论文生成工具&#xff0c;极大地提高了写作效率和质量。今天&#xff0c;我将向大家推荐五款免费的AI论文生成工具&#xff0c;并…

再也不用担心内容重复!在线伪原创工具,让创作更自由!

大家好&#xff0c;今天我们将讨论一个对网络写作非常有益的辅助工具——在线内容转换工具。不论您是需要更新您的博客&#xff0c;还是希望在社交平台上保持活跃&#xff0c;我们都频繁面临着迅速生成新内容的挑战。利用一个有效的工具来改写现有内容&#xff0c;可以极大地提…

一次实践:给自己的手机摄像头进行相机标定

文章目录 1. 问题引入2. 准备工作2.1 标定场2.2 相机拍摄 3. 基本原理3.1 成像原理3.2 畸变校正 4. 标定解算4.1 代码实现4.2 详细解析4.2.1 解算实现4.2.2 提取点位 4.3 解算结果 5. 问题补充 1. 问题引入 不得不说&#xff0c;现在的计算机视觉技术已经发展到足够成熟的阶段…

Python画笔案例-067 绘制配乐七角星

1、绘制橙子 通过 python 的turtle 库绘制 配乐七角星,如下图: 2、实现代码 绘制 配乐七角星 ,以下为实现代码: """配乐七角星.py本程序需要coloradd模块支持,安装方法:pip install coloradd""" import turtle from coloradd import color…

制造企业如何提升项目管理效率?惠科股份选择奥博思PowerProject项目管理系统

全球知名的显示方案综合服务商 - 惠科股份有限公司与北京奥博思达成合作&#xff0c;基于奥博思 PowerProject 搭建企业级项目管理平台。满足惠科多产品多业务领域的项目全周期管理。助力企业在技术研发、产品创新等方面继续取得行业领先优势。 同时&#xff0c;PowerProject …

如何进行u盘拷贝文件管控?5个方法一文详情告诉你!

小李&#xff1a;老王&#xff0c;最近我们部门经常提到数据安全的问题&#xff0c;特别是U盘拷贝文件带来的风险。 你有什么好办法可以管控一下吗&#xff1f; 老王&#xff1a;小李啊&#xff0c;你问对人了。 U盘拷贝文件管控确实是个头疼的问题&#xff0c;但我们可以从…

C++入门day5-面向对象编程(终)

C入门day4-面向对象编程&#xff08;下&#xff09;-CSDN博客 本节是我们面向对象内容的最终篇章&#xff0c;不是说我们的C就学到这里。如果有一些面向对象的基础知识没有讲到&#xff0c;后面会发布在知识点补充专栏&#xff0c;全都是干货满满的。 https://blog.csdn.net/u…

【中级通信工程师】终端与业务(九):市场细分与选择

【零基础3天通关中级通信工程师】 终端与业务(九)&#xff1a;市场细分与选择 本文是中级通信工程师考试《终端与业务》科目第九章《市场细分与选择》的复习资料和真题汇总。本章的核心内容涵盖了市场细分的概念与方法、目标市场选择策略以及市场定位的原则和步骤。通过本节的…

​fl studio21.2.3.4004中文版永久2024最新下载安装图文详细使用教程​

随着数字音乐制作的快速发展&#xff0c;越来越多的音乐制作软件涌现出来&#xff0c;而FL Studio无疑是其中的佼佼者。作为一款功能强大、易于上手的音乐制作软件&#xff0c;FL Studio V21中文版在继承了前代版本优秀基因的基础上&#xff0c;进一步提升了用户体验&#xff0…

用于MRI重建的具有全局感受野的傅里叶卷积块|文献速递--基于多模态-半监督深度学习的病理学诊断与病灶分割

Title 题目 Fourier Convolution Block with global receptive field for MRI reconstruction 用于MRI重建的具有全局感受野的傅里叶卷积块 01 文献速递介绍 从欠采样的磁共振成像&#xff08;MRI&#xff09;信号中重建图像可以显著减少扫描时间并改善临床实践。然而&…

rk3588S 调试USB摄像头

问题: 客户的 usb 摄像头 接上 板卡上的 USB2.0 的接口是可以的,但是 接上 typec 接口上的 OTGUSB的时候 ,就会出现,无法识别USB的问题。 情况的说明: 先来看一下硬件。 这里的 typec 接口实际上 只用到了 otg USB的 两根线, 也就是 把TYPEC 当做 USB2.0 来用了。(通…

Cannot read properties of undefined (reading ‘upgrade‘)

前端开发工具&#xff1a;VSCODE 报错信息&#xff1a; INFO Starting development server...10% building 2/2 modules 0 active ERROR TypeError: Cannot read properties of undefined (reading upgrade)TypeError: Cannot read properties of undefined (reading upgrade…

vxe-table制作高亮刷新功能

start 记录一下 vxe-table 实现表格新增数据背景闪烁功能。 1. 效果 2. demo代码 <template><div id"app"><div click"tomato">点我新增数据 lazy_tomato</div><vxe-grid refxTable :height"height" :columns&quo…

原文翻译:Make Skeleton-based Action Recognition Model Smaller, Faster and Better

全网没找到一个完整的翻译&#xff0c;用chatgpt翻译如下&#xff0c;可能有的地方不够准确&#xff0c;推荐结合原文对照着看更。 摘要 尽管基于骨架的动作识别在近年来取得了巨大的成功&#xff0c;但大多数现有方法可能面临模型规模庞大和执行速度缓慢的问题。为了解决这个…

Apifox 9月更新|「动态值」全新升级、跨团队引用接口和测试场景、测试报告交互优化

Apifox 新版本上线啦&#xff01;&#xff01;&#xff01; 看看本次版本更新主要涵盖的重点内容&#xff0c;有没有你所关注的功能特性&#xff1a; 「动态值」全新升级 更强大、更灵活的数据模拟能力 支持智能代码补全动态值 测试报告交互优化 支持跨团队引用接口和测试场…

LLM大模型学习:开源大模型技术路线及趋势

MLNLP社区是国内外知名的机器学习与自然语言处理社区&#xff0c;受众覆盖国内外NLP硕博生、高校老师以及企业研究人员。 社区的愿景是促进国内外自然语言处理&#xff0c;机器学习学术界、产业界和广大爱好者之间的交流和进步&#xff0c;特别是初学者同学们的进步。 转载自…

数电基础(组合逻辑电路+Proteus)

1.组合逻辑电路 1.1组合逻辑电路的分析 1.1.1组合逻辑电路的定义 组合逻辑电路的定义 &#xff08;1&#xff09;对于一个逻辑电路&#xff0c;其输出状态在任何时刻只取决于同一时刻的输入状态&#xff0c;而与电路的原来状态无关&#xff0c;这种电路被定义为组合逻辑电路…

MySQL 之索引详解

想象一下&#xff0c;你正在图书馆寻找一本关于 MySQL 索引的书。图书馆里有成千上万本书&#xff0c;但没有目录。你只能一排一排、一本一本地找&#xff0c;直到找到你想要的书。这将会花费大量的时间&#xff01;数据库索引就像图书馆的目录一样&#xff0c;可以帮助数据库系…