【CSS in Depth 2 精译_021】3.4 负的外边距 + 3.5 外边距折叠

news2024/9/21 20:44:09

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

  • 第一章 层叠、优先级与继承(已完结)
    • 1.1 层叠
    • 1.2 继承
    • 1.3 特殊值
    • 1.4 简写属性
    • 1.5 CSS 渐进式增强技术
    • 1.6 本章小结
  • 第二章 相对单位(已完结)
    • 2.1 相对单位的威力
    • 2.2 em 与 rem
    • 2.3 告别像素思维
    • 2.4 视口的相对单位
    • 2.5 无单位的数值与行高
    • 2.6 自定义属性
    • 2.7 本章小结
  • 第三章 文档流与盒模型
    • 3.1 常规文档流(已完结)
      • 3.1.1 内容水平居中
      • 3.1.2 逻辑属性
      • 3.1.3 用好逻辑属性的简写形式
    • 3.2 盒模型(已完结)
      • 3.2.1 避免使用魔数
      • 3.2.2 调整盒模型
      • 3.3.3 全局设置 border-box
    • 3.3 元素的高度
      • 3.3.1 控制溢出行为
      • 3.3.2 百分比高度的备选方案
      • 3.3.3 使用 min-height 和 max-height
    • 3.4 负的外边距 ✔️
    • 3.5 外边距折叠 ✔️
      • 3.5.1 文字折叠 ✔️
      • 3.5.2 多个外边距折叠 ✔️
      • 3.5.3 向容器外折叠 ✔️
    • 3.6 容器内的元素间距问题 (精译中 ⏳)
      • 3.6.1 当内容改变时的处理 (精译中 ⏳)
      • 3.6.2 更通用的解决方案 (精译中 ⏳)

文章目录

    • 3.4 负的外边距
    • 3.5 外边距折叠
      • 3.5.1 文字折叠
      • 3.5.2 多个外边距折叠
      • 3.5.3 容器外部折叠

3.4 负的外边距

与内边距和边框宽度不同,外边距可以设为负值。负的外边距有一些特殊用途,例如让元素重叠,或者拉伸到比容器还宽。

负外边距的具体行为取决于设置在元素的哪边,如图 3.13 所示。如果作用于左侧或顶部,则负外边距会分别将元素向左、向上移动,导致元素在文档流中与前面的元素重叠。但如果应用于底部,负外边距则不会移动该元素,而是将其下方的元素拉上来;这和直接给正下方的元素一个负的顶部外边距的效果类似。

图 3.13 负外边距的行为特征

图 3.13 负外边距的行为特征

尽管负外边距可用于制造多个元素间的重叠效果,但任何复杂的样式追踪起来都会比较麻烦。通常情况下,更推荐使用定位属性 position 来实现该效果;有关定位的知识将在第 6 章中详细介绍。

警告

通过负的外边距实现的元素重叠效果,可能会让包含交互逻辑的元素挪到其他元素后面,从而导致无法正常点击。

根据元素是行内元素还是块级元素,负的右外边距的行为特征也不尽相同。对于行内元素,其行为模式类似于负的下外边距,会将后续内容往左侧拉动,进而与该元素重叠;但在实践中我从未使用过这种方法。

而对于块级元素,负的右外边距则会向右侧拉动元素边缘,使元素扩宽。这可能导致元素边缘超出容器。

此时若将负的左外边距联系起来,元素的左右两边则会延伸到容器外部,致使宽度超过容器宽度。这就是双容器模式(double container pattern,详见 3.1.1 小节内容)的另一种应用,如图 3.14 所示。

图 3.14 负的左右外边距将块级元素扩展到其容器外部示意图

图 3.14 负的左右外边距将块级元素扩展到其容器外部示意图

上述效果的样式代码如代码清单 3.9 所示。该方法可用实现图片的“流布溢出(bleed)”效果,令其宽度大于所在文本列。

代码清单 3.9 负的外边距让图片溢出容器

.container {
  max-width: 1080px;
  margin-inline: auto;
}
.expanded-child {
  margin-inline: -2em; /* 致使元素在两个方向扩宽到容器外部 */
}

注意,该方案也可能导致内容超出浏览器视口。因此在实际应用时要注意样式在小屏幕上仍能正常生效。

3.5 外边距折叠

在回到本章的示例页,有没有发现有些外边距不对劲?标题或容器并没有设置过外边距,但却出现了间距(如图 3.15 所示)。这个间距是哪儿来的呢?

图 3.15 外边距折叠导致的间距

图 3.15 外边距折叠导致的间距

当顶部和(或)底部的外边距相邻时,就会重叠为一个单独的外边距。这种现象称为 折叠(collapsing。图 3.15 中标题栏下方的空白就是外边距折叠导致的。一起来看看它的工作原理。

3.5.1 文字折叠

外边距折叠主要与包含文本的块级元素间的间距有关。默认情况下,段落元素(<p>)的上下外边距均为 1em,由用户代理样式表指定。但当两个段落紧挨着排列时,其实际外边距并不会相加得到 2em,而是会相互折叠,只产生 1em 的间距。

可以在示例页的 <main> 元素中看到该折叠效果。元素 <h2> 内的标题(即“Come join us!”)其底部外边距为 0.83em,与下方段落的顶部外边距折叠。二者的外边距分布情况如图 3.16 所示。注意观察它们各自的外边距是怎样在页面上占据相同位置的:

图 3.16 标题(左侧)与段落(右侧)勾勒出的外边距示意图

图 3.16 标题(左侧)与段落(右侧)勾勒出的外边距示意图

外边距折叠后的实际大小,等于参与折叠的外边距中较大的一方。本例中,标题栏的底部外边距为 19.92px(字号 24px × 0.83em 外边距),而段落的顶部外边距为 16px(字号 16px × 1em 外边距);二者较大的一方 19.92px 即为实际的外边距大小。

3.5.2 多个外边距折叠

就算两个元素不是相邻的同级元素,外边距也会折叠。例如将段落元素 p 包裹在一个 div 中,如代码清单 3.10 所示,折叠效果也是一样的。在没有任何其他 CSS 干预的情况下,所有相邻的上下外边距都会发生折叠

代码清单 3.10 用 div 包裹的段落其外边距同样会发生折叠

<main class="main">
  <h2>Come join us!</h2>
  <div><!-- 即便用另一个 div 包裹起来,段落的外边距仍会折叠 -->
    <p>
      The Franklin Running club meets at 6:00pm
      every Thursday at the town square. Runs
      are three to five miles, at your own pace.
    </p>
  </div>
</main>

本例中,三个不同元素的外边距折叠在了一起:<h2> 的底部外边距、以及 <div><p> 各自的顶部外边距。这些样式属性的计算值分别为 19.92px0px16px。因此元素之间最终的间距(space)仍然是 19.92px,即三者中的最大值。就算将段落元素嵌套进多个 div 容器中,最终渲染的效果还是不变——所有的外边距都折叠到一块儿了。

总之,任何相邻元素的上下外边距都会折叠到一起。如果在页面中添加一个空的、无样式的 div 元素(即没有指定高度、边框或内边距),其自身的上下外边距也会折叠。

注意

外边距折叠只针对上下外边距;左右外边距不会折叠。(纵向书写模式下情况则刚好相反,此时会折叠的反倒是左右外边距)。

折叠的外边距就像是“个人安全距离”(个人安全距离)。如果站在公交车站的两个人都觉得保持 3 英尺(译注:1 英尺约合 0.3048 米)的距离很舒服,那他们会很乐意间隔 3 英尺,不必非要间隔 6 英尺才会感到舒适。

这就意味着在设置元素外边距时,不用太在意其上方或下方内容的干扰。如果设置标题的底部外边距为 1.5em,则无论下方元素是 margin-top1em<p>,还是不带外边距的 <div>,其间距均为 1.5em(译注:这里假设 1.5em 的计算值更大)。只有当下方的元素需要更多间距时,折叠后的外边距才会增大。

3.5.3 容器外部折叠

三个连续的外边距折叠可能会让您措手不及。如果容器带了背景样式,元素的外边距在容器外部折叠通常会产生不理想的效果。

这就是导致标题下方出现空隙的原因。页面标题是一个 <h1> 元素,用户代理样式设置了 0.67em(即 21.44px)的底部外边距。标题位于无边距的 <header> 中。这两个元素的底部外边距相邻,因此它们会折叠,从而导致标题的底部外边距为 21.44px。同样的情况也出现在两个元素的顶部外边距上。

这样就有点奇怪了。本希望 <header> 的蓝色背景在纵向上更宽一些,这样标题周围就留出了足够的空间;但外边距未必会在预想的位置发生折叠。还好有很多种方法来避免这种情况发生,并且在之前的页面正文区域其实以及处理过该类问题了;注意观察,“Come join us!”字样上方的外边距并没有折叠到容器外面。这是因为容器设置了内边距 padding,如果外边距之间有任何内边距样式,它们就不会折叠。

如果为 header 容器添加上下内边距,其内部元素的外边距就不会折叠到容器外;也就是说,<h1> 的外边距和 <header> 的内边距都会为标题文本提供空间,略显冗余。此时最佳的解决方案可能需要完全去掉 h1 元素的外边距,让容器 header 的内边距来指定所需空间。

图 3.17 为标题栏设置内边距,防止外边距折叠

图 3.17 为标题栏设置内边距,防止外边距折叠

按照代码清单 3.11 更新样式,会发现标题区和正文区之间不再有间隙。这个问题稍后再来解决。

代码清单 3.11 给标题栏加上内边距样式

当容器上方或下方出现意外的空白,或者文本被压到容器的顶部或底部时,罪魁祸首很可能就是外边距折叠。

  • 对容器应用 overflow: auto(或者非 visible 的值),可以防止内部元素的外边距与容器外边距发生折叠。通常这种方案副作用最小。
  • 在两个外边距间添加边框或内边距,防止外边距折叠。
  • 对于容器为内联块(inline-block)级元素(其元素是浮动的,详见第 12 章)、或者设置了绝对或固定定位的元素(详见第 6 章),外边距不会在容器外部折叠。
  • 使用 Flexbox 弹性盒布局或 Grid 网格布局时,布局内的元素间不会发生外边距折叠(详见第 4 章和第 5 章)。
  • display 属性为 table-cell 的元素没有外边距,因此不会折叠。这也适用于值为 table-row 的元素以及大部分表格型的样式值,但 tabletable-inlinetable-caption 除外。

上述这些方法很多会改变元素的布局行为,所以除非能产生理想的布局效果,否则不要轻易使用。

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

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

相关文章

【思源笔记】思源笔记配置S3同步

本文首发于 ❄️慕雪的寒舍 文章目录 1. 写在前面2. 什么是思源笔记的S3/WEBDAV同步&#xff1f;2.1. 说明2.2. 思源的同步配置和工作空间2.3. 什么是S3协议&#xff1f; 3. 配置思源S3同步3.1. 初始化数据仓库密钥3.2. 思源S3同步界面3.3. 配置七牛云KODO3.4. 如何将同步配置导…

排队免单小程序

本文来自&#xff1a;排队免单小程序 - 源码1688 应用介绍 排队免单小程序是基于移动互联网技术开发的平台系统&#xff0c;通过小程序的形式为消费者和商家搭建了一个互动桥梁。以下是对排队免单小程序的详细介绍&#xff1a; 一、基本概念 排队免单小程序是一种创新的营销工…

Qt与SVG

Qt之SVG&#xff1a;Qt简单使用SVG的介绍_qt svg-CSDN博客 <?xml version"1.0" standalone"no"?> <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg xml…

15 种高级 RAG 技术 ——从预检索到生成

15 种高级 RAG 技术 ——从预检索到生成 检索增强生成&#xff08;RAG&#xff09;是一个丰富、快速发展的领域&#xff0c;它为增强由大型语言模型&#xff08;LLM&#xff09;驱动的生成式人工智能系统创造了新的机会。在本指南中&#xff0c;WillowTree的数据与人工智能研究…

工业一体机,为工业自动化提供完美解决方案

近年来&#xff0c;智能制造成为全球制造业转型升级的必然趋势&#xff0c;而工业自动化作为智能制造的关键环节&#xff0c;其重要性日益凸显。在这一趋势下&#xff0c;工业一体机凭借其高度集成、稳定可靠、灵活高效等优势&#xff0c;成为了工业自动化领域中不可或缺的“利…

Mysql的查询指令

整理了一些Mysql的查询语句&#xff0c;希望对大家有帮助&#xff0c;祝大家心想事成万事如意&#xff01; 基本查询 select 字段 from 表名 where 条件&#xff1b; 排序查询 select 字段 from 表名 order by 排序字段 [asc升序|desc降序] limit 前几行/中间几行&#xff1…

Nature methods | FlowSig--揭示细胞间流动网络新方法!有具体代码可实操!

–https://doi.org/10.1038/s41592-024-02380-w Inferring pattern-driving intercellular flows from single-cell and spatial transcriptomics FlowSig是刚刚&#xff08;8月26日&#xff09;发表在nature methods上的新文章&#xff0c;该方法系统性地推断出由细胞间通信…

Ubuntu系统使用Docker部署中文版trilium并实现远程编辑笔记

文章目录 前言1. 安装docker与docker-compose2. 启动容器运行镜像3. 本地访问测试4.安装内网穿透5. 创建公网地址6. 创建固定公网地址 前言 今天和大家分享一款在G站获得了26K的强大的开源在线协作笔记软件&#xff0c;Trilium Notes的中文版如何在Linux环境使用docker本地部署…

GPT微调和嵌入哪个好,大模型微调 和嵌入有什么区别?微调(fine-tuning),嵌入(embedding)的用法!

GPT擅长回答问题&#xff0c;但是只能回答它以前被训练过的问题&#xff0c;如果是没有训练过的数据&#xff0c;比如一些私有数据或者最新的数据该怎么办呢&#xff1f; 这种情况下通常有两种办法&#xff0c;一种是微调&#xff08;fine-tuning&#xff09;&#xff0c;一种…

四大神器:2024免费数据恢复软件推荐!

在这个数字化的时代&#xff0c;数据丢失可能是我们最不想面对的事情之一。但不用担心&#xff0c;今天我就来给大家介绍几款免费又好用的数据恢复软件&#xff01; 第一款&#xff1a;福昕数据恢复 链接&#xff1a;www.pdf365.cn/foxit-restore/ 这是一款由福昕公司推出的…

Vue3+Ts封装input组件时遇到的问题

使用input事件监听输入框变化时&#xff0c;如果当前使用的输入法是中文&#xff0c;他也会触发input事件&#xff0c;正常来说&#xff0c;中文没有输入完毕是不用触发事件的。 控制台打印时发现&#xff1a; 那么我们应该怎么去规避这件事呢&#xff1f; 其实input还有几个事…

从永远到永远-日语学习-て形用法及变形规律

て形用法及变形规律 0.前置知识1.常见用法1.请求某人做某事 「&#xff5e;てください」2.几个连续发生的动作 &#xff5e;て、&#xff5e;て、&#xff5e;て3.两个动作先后发生「てから」4. 表示许可 「てもいいです」5.表示禁止 「&#xff5e;てはいけません」6.「&#…

亚马逊新品如何获取评论,为店铺提高产品排名权重流量订单?测评

大多数消费者都会购买具有最佳评论和评级的产品。亚马逊评论是影响消费者决策的关键因素&#xff0c;卖家对评论的重视程度也非常之高&#xff0c;亚马逊卖家最常见的挑战之一是获得产品评论。 1.亚马逊Vine计划&#xff1a; 亚马逊Vine计划是亚马逊为品牌卖家提供的专属评论计…

猫咪浮毛如何清理?希喂、安德迈、范罗士宠物空气净化器功能实测

拥有一只属于自己的小猫咪&#xff0c;是一件非常幸福的事。美中不足的就是它掉毛&#xff0c;疯狂的掉毛&#xff0c;家里到处都是毛发散落的痕迹。和它亲近的时候&#xff0c;也会沾满一身毛&#xff0c;清理起来非常麻烦。特别是随着季节的转换&#xff0c;猫咪换毛季的到来…

使用IntelliJ IDEA将本地项目推送到远程Git

1&#xff0c;安装Git 打开 下载地址&#xff0c;下载Git安装包。根据引导程序&#xff0c;完成安装。 2&#xff0c;IntelliJ IDEA配置Git 打开IntelliJ IDEA&#xff0c;依次点击File>>Settings…>>Git&#xff0c;然后配置自己的Git的路径&#xff0c;然后点…

系统架构分析

一、速通一图流 二、系统架构功能、作用分析 1. Furion&#xff1a;框架核心层 功能&#xff1a;这是 Furion 框架的核心层&#xff0c;通常包含框架本身的基本功能和配置。这一层应该是比较稳定的&#xff0c;不应该包含业务逻辑&#xff0c;而是提供项目其他部分需要依赖的…

yolo7 自定义数据训练

数据打标labelimg 预定义标签 格式name label 数据集定义文件errimg.yaml train: /home/kean/works/yolov7/dataset/train.txt val: /home/kean/works/yolov7/dataset/val.txt # number of classes nc: 1 # class names names: ["error_dialog"] 数据定义文件train.…

【JS】使用MessageChannel实现深度克隆

前言 通常使用简便快捷的JSON 序列化与反序列化实现深克隆&#xff0c;也可以递归实现或者直接使用lodash。 但 JSON 序列化与反序列化 无法处理如下的循环引用&#xff1a; 实现 MessageChannel 内部使用了浏览器内置的结构化克隆算法&#xff0c;该算法可以在不同的浏览器上…

学习之在window上安装MySQL server 并连接到Navicat

一、下载 下载地址&#xff1a;https://www.mysql.com/ 二、安装 1、双击软件安装2、点击yes

【解析几何笔记】9. 向量的内积运算

9. 向量的内积运算 定义&#xff1a;有向量 α , β \pmb{\alpha},\pmb{\beta} α,β&#xff0c; α ⋅ β ∣ α ∣ ∣ β ∣ ⋅ cos ⁡ < α , β > \pmb{\alpha}\cdot\pmb{\beta}|\pmb{\alpha}||\pmb{\beta}|\cdot\cos<\pmb{\alpha},\pmb{\beta}> α⋅β∣α…