商城网站设计公司怎么样,asp网站开发模板,wordpress生成封面分享,企业网站是什么当前内容所在位置#xff08;可进入专栏查看其他译好的章节内容#xff09; 第一章 层叠、优先级与继承#xff08;已完结#xff09;第二章 相对单位#xff08;已完结#xff09;第三章 文档流与盒模型#xff08;已完结#xff09;第四章 Flexbox 布局#xff08;已… 当前内容所在位置可进入专栏查看其他译好的章节内容 第一章 层叠、优先级与继承已完结第二章 相对单位已完结第三章 文档流与盒模型已完结第四章 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-indexStacking contexts and z-index6.4.1 理解渲染过程与堆叠顺序 Understanding the rendering process and stacking order6.4.2 用 z-index 控制堆叠顺序 Manipulating stacking order with z-index 《CSS in Depth》新版封面 译者按 前面利用 CSS 的定位技术相继实现了模态对话框和下拉菜单的效果这一节将重点处理二者在页面渲染时出现的意外堆叠问题。本节内容非常重要由于篇幅较长特地分为上篇和下篇进行介绍。本篇为上篇先讲讲堆叠问题的具体处理。下一篇再深入原理彻底弄清堆叠上下文的核心概念及行为模式。其实阻碍前端开发人员进阶中高级水平的往往就是这些平时就掌握得模棱两可的核心概念即便工作中遇到过事后也鲜有及时复盘与梳理。让我们跟随作者的脚步一起持续深耕潜心积累 6.4 堆叠上下文与 z-indexStacking contexts and z-index
定位技术Positioning固然实用但更重要的是弄明白它会带来什么样的意外情况。一个元素自从脱离文档流后之前由文档流负责的工作从此也将由您来全面接管。
比如要时刻确保该元素不会意外跑到浏览器视口viewport的外面让用户找不着它其次必须保证该元素不会意外挡住页面上的重要内容。
最后还要考虑元素堆叠stacking方面的问题。在同一页面定位多个元素时很可能会遇到两个不同的定位元素发生重叠的情况并且偶尔还会发现它们并没有乖乖按照我们预想的方式进行重叠。其实本章的示例已经有意设置了这样的问题场景以便进一步演示该如何处理。
根据之前示例页面的设计需求点击页面顶部的注册按钮即 “Sign up” 字样的按钮就能打开一个模态对话框。要是把下拉菜单相关的 HTML 标记放到模态框的源码后面最终效果就会如下图 6.10 所示下拉菜单意外挡在了模态对话框的前面 图 6.10 模态框错误地出现在下拉菜单的后面
解决这个问题有很多种方案。在此之前有必要先了解一下浏览器确定元素堆叠顺序的基本原理。为此需要进一步考察一个页面在浏览器中的渲染过程。
6.4.1 理解渲染过程与堆叠顺序 Understanding the rendering process and stacking order
在浏览器将 HTML 解析为 DOM 时它还会同步创建一个新的树形结构称为 渲染树render tree。该渲染树不仅体现了每个元素的视觉样式和位置同时也决定着浏览器 绘制paint 这些元素的顺序。该顺序 极其重要一旦发生重叠后绘制的元素就会出现在先绘制的元素上。
通常情况下即使用 CSS 定位前该绘制顺序由元素在 HTML 中出现的源码顺序决定。以如下 HTML 标记的这三个元素为例
divone/div
divtwo/div
divthree/div它们相互间的堆叠行为将如图 6.11 所示。这里使用了负的外边距来让元素重叠但并没有设置任何定位。可以看到源码位置靠后的元素绘制在了位置靠前的元素上 图 6.11 正常情况下三个元素的堆叠效果
而设置定位后情况就不同了。浏览器会优先绘制所有未被定位的元素non-positioned elements然后再绘制已定位的元素。默认情况下已定位的所有元素都会出现在尚未定位的元素前面to the front。如图 6.12 所示给前两个元素加上 position: relative 后它们就绘制到前面去了覆盖了静态定位下的第三个元素尽管元素在 HTML 中的源码顺序并未改变。
注意在定位的这两个元素中第二个元素还是绘制在了第一个元素的前面。虽然定位元素都被放到了前面但它们之间基于源码的重叠关系仍旧不变。 图 6.12 已定位的元素绘制在了静态元素的前面
也就是说此时的示例页中模态框和下拉菜单都会出现在静态内容之前符合预期但源码里后出现的元素还是会绘制到先出现的元素前面。要解决这个问题有一种方案是将 div classmodal 及其所有内容全部移动到下拉菜单 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-backdrop 的 z-index 值为 1、且元素 modal-body 的 z-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 版高分译文专栏全网首发精译精校持续更新计划今年内完成全书翻译敬请期待