父元素的边距包含不一致
当有边距的元素放置在另一个元素中时,父元素并不总是一致地换行或包含该边距。这种不一致似乎违反直觉,尤其是与边框、位置、显示和溢出等其他属性的行为相比。
重叠边距和折叠
直觉上,人们可能会假设 CSS 规范中描述的边距折叠会影响此行为。然而,尽管跨浏览器不存在重叠边距和一致的行为,但这种不一致的根源在于其他地方。
边距包含背后的逻辑
CSS 规范实际上定义了这种行为虽然带有一些矛盾。规范讨论了“自由边距”(超出父元素的边距)和“折叠边距”(重叠的相邻边距),但没有明确区分每种边距的适用条件。
演示和结论
以下演示说明了这种不一致的行为:
<code class="html"><div class="block"> <h2 id="Is-the-margin-contained-block">Is the margin contained (block)?</h2> </div> <div class="inline-block"> <h2 id="Is-the-margin-contained-inline-block">Is the margin contained (inline-block)?</h2> </div> <div class="position-absolute"> <h2 id="Is-the-margin-contained-position-absolute">Is the margin contained (position-absolute)?</h2> </div> <div class="overflow-auto"> <h2 id="Is-the-margin-contained-overflow-auto">Is the margin contained (overflow-auto)?</h2> </div> <div class="border"> <h2 id="Is-the-margin-contained-border">Is the margin contained (border)?</h2> </div></code>
将“块”元素(及其默认边距行为)与所有其他元素进行比较时,不一致是显而易见的元素。看起来,除了常规 div 的默认行为之外,所有内容都假定边距由父级包含。
这种复杂的行为源于 CSS 规范中关于边距折叠和可用边距的模糊性。不幸的是,文档没有提供关于这些概念如何与不同元素属性(如边框、位置和溢出)交互的清晰解释。
以上是为什么父元素并不总是包含一致的子元素边距?的详细内容。更多信息请关注PHP中文网其他相关文章!

对于Astro,我们可以在构建过程中生成大部分网站,但是有一小部分服务器端代码可以使用Fuse.js之类的搜索功能来处理搜索功能。在此演示中,我们将使用保险丝搜索一组个人“书签”


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

SublimeText3 Linux新版
SublimeText3 Linux最新版