CSS - 高度坍塌和外边距溢出问题及解决方法

时间:2019-08-31
本文章向大家介绍CSS - 高度坍塌和外边距溢出问题及解决方法,主要包括CSS - 高度坍塌和外边距溢出问题及解决方法使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

CSS - 高度坍塌和外边距溢出

高度坍塌

  1. 成因

    • 父元素未设置高度
    • 子元素全部设置浮动(float: left | right;),浮动元素 脱离文档流不占页面空间
    • 由于父元素为设置高度,高度靠内部子元素撑开,而今子元素全部脱离文档流,所以此时父元素的高度为 0,给父元素和子元素设置 边框border: 1px solid #000;)或者 显示父元素轮廓outline: 1px solid #000;),会出现子元素超出了父元素的区域范围的现象,即为:高度坍塌现象。
  2. 解决方法

    2.1 根据子元素的最大高度为父元素设置高度

    • 前提是要知道子元素高度

    2.2 父元素也设置为浮动

    • 会影响父元素的兄弟元素,可能破坏原有的页面布局

    2.3 父元素设置 overflow: auto | hidden; 属性

    • 只要溢出的内容一律都会被隐藏,可能会隐藏不想被隐藏的部分

    2.4 为父元素增加伪元素(推荐)

    • /**
       .div-parent 为父元素类选择器
       设置 content 为空,父元素最后一个伪元素子元素内容为空
       clear: both 会清除该元素左右两端的所有的浮动元素,即该元素在父元素中处于所有子元素的最     下方,且存在于文档流中,占页面空间;父元素识别到该元素将会自适应高度
      */
      .div-parent::after {
          display: table;
          content: "";
          clear: both;
      }

原文地址:https://www.cnblogs.com/kldn208/p/11439842.html