zoukankan      html  css  js  c++  java
  • 理解css的BFC

               BFC是CSS中一个看不见的盒子,(先理解CSS的盒子模型)。它的页面渲染方式与普通流的盒子模型不同,它决定了其子元素将如何定位(所用属于BFC的box 都默认左对齐),以及和其他元素的关系和相互作用 。如何才能形成BFC盒模型呢?

                1.float 属性值不为none;

                2.position 属性值不为 static 和 relative;

                3.display 属性为:table-cell || table-caption || inline-block || flex || inline-flex;

                4.overflow 属性不为 visible。

           产生BFC比较好的方式是overflow : hidden。

           那BFC盒模型有什么作用呢?

           1.解决Margin Collapse

            普通流以及在BFC盒子中的box 都会有Margin Collapse 问题。那么什么是Margin Collapse 呢?即上下垂直排列的两个box之间的Margin值,并不是两个box的Margin值的叠加,而是按照如下规则:<1>当两个Margin值都为正或者负值时,Margin  Value = (|Margin1|>=|Margin2|? Margin1 , Margin2)<2>  当一个值为正,一个值为负时Margin Value = Margin1 + Margin2。如何解决?  两个不同的BFC块则没有Margin Collapse 问题。

           2.解决float带来的父级元素坍塌的问题, 将float元素的父元素定义为BFC盒模型。

          3.形成如Figure 2 所示的布局,将文字块包裹在BFC盒模型中。

           .


           

  • 相关阅读:
    Java 流(Stream)、文件(File)和IO
    Java集合笔记
    希尔排序
    多线程
    查找算法
    快速排序
    leetcode题解58
    9.回文数
    SonarQube代码质量管理平台安装及使用
    用GitBlit 和 VS GitSourceControlProvider 搭建基于 Http(s) 的 Git 工作平台
  • 原文地址:https://www.cnblogs.com/wust-hy/p/7349156.html
Copyright © 2011-2022 走看看