CSS之margin塌陷

这篇具有很好参考价值的文章主要介绍了CSS之margin塌陷。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

margin塌陷

CSS中的外边距塌陷(Margin Collapse)问题是指在垂直方向上,当两个或多个块级元素的边距相遇时,它们之间的距离不是它们各自边距的总和,而是其中的最大值。这种现象主要出现在块级元素的上下外边距之间。

  <div class="box ac">Box 1</div>
  <div class="box bc">Box 2</div>
    .box {
      width: 100px;
      height: 100px;
      color: white;
    }

    .ac {
      background: red;
      margin-bottom: 20px;
    }

    .bc {
      background: blue;
      margin-top: 30px;
    }

CSS之margin塌陷,CSS,css,前端
.ac和.bc有上下margin但是只生效了一个最大值。

产生原因

外边距塌陷只发生在垂直方向的块级元素上,原因如下:
  • 相邻兄弟元素:垂直排列的两个兄弟元素之间的边距会发生塌陷。
  • 父子元素边距:当一个块级元素为空(或高度为0),并且它的上(和/或)下边距有值时,如果它与子元素之间没有边框、内边距、内联内容、或创建了BFC(块格式化上下文)的元素分隔,那么它的边距会和子元素的边距发生塌陷。
  • 空块级元素的边距:如果一个块级元素不包含任何内容,并且它的上下边距都有值,这两个边距可能会发生塌陷。

解决方案

  • 使用边框(border)或内边距(padding):通过设置border或者padding来解决。
.ac {
      background: red;
      margin-bottom: 20px;
      border-bottom: 20px solid white;
}
  • 创建块格式化上下文(BFC):在元素上创建一个新的BFC可以阻止它与外部元素的外边距塌陷,常见的创建BFC的方法包括设置元素的overflow属性为hidden、auto, 或者 scroll。

HTML:

    <div class="container">
      <div class="box ac">Box 1</div>
    </div>
    <div class="box bc">Box 2</div>

CSS:

      .box {
        width: 100px;
        height: 100px;
        color: white;
      }

      .ac {
        background: red;
        margin-bottom: 20px;
      }

      .bc {
        background: blue;
        margin-top: 30px;
      }

      .container {
        overflow: hidden;
      }

CSS之margin塌陷,CSS,css,前端文章来源地址https://www.toymoban.com/news/detail-833524.html

  • 使用伪元素:在父元素中添加伪元素,并为伪元素设置display: table;,这样可以阻止与子元素之间的外边距塌陷。
      .container {
        display: table;
      }
  • 设置display: flex或display: grid:为父元素设置Flex或Grid布局会创建一个新的布局上下文,也可避免边距塌陷。
      .container {
        display: flex;
      }

到了这里,关于CSS之margin塌陷的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • uniapp css使用margin的时候导致出现垂直滚动条问题

    最开始不知道是怎么回事,页面明明还没有到达底部,怎么就出现垂直滚动条了。这里的原因就是最外层或者比较外层的view使用了margin就会出现这样的情况。换成padding不会。这是最简单的原因,你可以试一下下面的结构,必然触发,触发条件非常的简单。 大致结构如下:

    2024年02月11日
    浏览(7)
  • 在CSS中,盒模型中的padding、border、margin是什么意思?

    在CSS中,盒模型中的padding、border、margin是什么意思?

    在CSS中,盒模型(Box Model)是用来描述和布局HTML元素的基本概念。它将每个HTML元素看作是一个矩形的盒子,这个盒子包括了内容(content)、内边距(padding)、边框(border)和外边距(margin)这几个重要的部分。这些部分一起决定了元素在页面中的大小和定位。 下面是这些

    2024年02月11日
    浏览(10)
  • CSS - 你遇到过子元素设置margin-top,影响父元素的情况吗

    CSS - 你遇到过子元素设置margin-top,影响父元素的情况吗

    难度级别:初级及以上                                 提问概率:60%  例如在一个div盒子元素内,需要设置一个标题,我们用一个p标签做为这个标题元素。根据UI设计要求,标题元素需要距离父div元素20px,理所当然想到的就是为标题元素设置margin-top为20px,

    2024年04月08日
    浏览(8)
  • 【前端 - CSS】第 17 课 - CSS 特性

    【前端 - CSS】第 17 课 - CSS 特性

            欢迎来到博主 Apeiron 的博客,祝您旅程愉快 ! 时止则止,时行则行。动静不失其时,其道光明。 目录 1、缘起 2、CSS 三大特性 2.1、继承性 2.2、层叠性 2.3、优先级 3、总结          CSS 是一种用于样式化网页的语言,它具有 选择器 和 属性 的结构。通过

    2024年02月10日
    浏览(10)
  • 前端基础HTML、CSS--6(CSS-3)

    前端基础HTML、CSS--6(CSS-3)

    1.CSS的三大特性 CSS有三个非常重要的三个特性:层叠性、继承性、优先级。 1.1层叠性 相同选择器给设置相同的样式 ,此时一个样式就会 覆盖(层叠) 另一个冲突的样式。层叠性主要解决样式冲突的问题。 层叠性原则: ·样式冲突,遵循的是 就近原则 ,哪个样式离结构近

    2023年04月08日
    浏览(11)
  • 前端三剑客CSS篇——CSS选择器

    前端三剑客CSS篇——CSS选择器

    CSS是前端三剑客不可忽略的一部分,CSS对前端来说是一个美化页面的工具,而且其功能十分强大,程序员可以如果熟练运用的话可以‘随心所欲’的更改页面的样式,使得页面更加美观。 CSS标签是由 键值对 的模式来排列的。 CSS三大特征👍 学习CSS之前,先认识一下CSS的三大

    2024年02月04日
    浏览(9)
  • 前端框架的CSS模块化(CSS Modules)

    前端框架的CSS模块化(CSS Modules)

    创作纪念日之际,来给大家分享一篇文章吧 聚沙成塔·每天进步一点点 前端入门之旅:探索Web开发的奇妙世界 欢迎来到前端入门之旅!感兴趣的可以订阅本专栏哦!这个专栏是为那些对Web开发感兴趣、刚刚踏入前端领域的朋友们量身打造的。无论你是完全的新手还是有一些

    2024年03月27日
    浏览(11)
  • CSS样式前端HTML页面常用CSS效果实现及其相关配置信息------前端入门基础教程

    !DOCTYPE html !-- 这是HTML的注释 -- html lang=\\\"en\\\" id=\\\"myHtml\\\"     head         !-- 这里不是设置了编码,而是告诉浏览器,用什么编码方式打开文件避免乱码 --         meta charset=\\\"UTF-8\\\"         meta name=\\\"viewport\\\" content=\\\"width=device-width, initial-scale=1.0\\\"         titleHtmlAll/title         

    2024年02月05日
    浏览(16)
  • 【前端|CSS系列第4篇】CSS布局之网格布局

    【前端|CSS系列第4篇】CSS布局之网格布局

    最近在做的一个项目前台首页有一个展示词条的功能,每一个词条都以一个固定大小的词条卡片进行展示,要将所有的词条卡片展示出来,大概是下面这种布局 每一行的卡片数目会随着屏幕大小自动变化,并且希望整个卡片区域周围不要有太大的留白,可是由于本人css学的并

    2024年02月16日
    浏览(7)
  • 【前端面经】CSS-CSS的工程化

    CSS 工程化的目的是解决以下问题: 宏观设计 :如何组织 CSS 代码、如何拆分、如何设计模块结构? 编码优化 :如何编写更好的 CSS 代码? 构建 :如何处理 CSS 代码,以让打包结果最佳? 可维护性 :代码写完后,如何最小化后续变更的成本?如何确保任何同事都能轻松接手

    2024年02月03日
    浏览(5)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包