CSS中的IFC和BFC入门
提到CSS,首先会想到的就是盒模型,若是对于盒模型不是很理解的,看这里。这是一个基础的系列,看了盒模型还能够看看box-sizing,好了很少说了,下面介绍今天的重点。css
首先从概念入门,B是Block,I是inline,F [Formatting] C [context]。一句话归纳就是格式化上下文一个是块级,一个是行级。html
BFC有以下规则:app
- 内部的盒子会在垂直方向,一个个的放置;
- BFC是页面上的一个隔离的容器
- 属于同一个BFC的 两个相邻Box的 上下margin会发生重叠
- 计算BFC的高度时,浮动元素也参与计算
- BFC的区域不会与float重叠;
触发BFC的条件:布局
-
body 根元素;post
-
浮动元素:float 不为none的属性值;flex
-
绝对定位元素:position (absolute、fixed)spa
-
display为: inline-block、table-cells、flexcode
-
overflow 除了visible之外的值 (hidden、auto、scroll)orm
这里提出一点,规则是做用于BFC内部的元素,而条件则是做用于BFC容器的,这点要理解。xml
这些只是概念,要想理解,还得结合一些例子来看。
布局规则一二条是概念,就不介绍了。第三条:
- .p {
- width:200px;
- height:50px;
- margin:50px 0;
- background-color:red;
- }
-
<body>
-
<div class="p"> </div>
-
<div class="p"> </div>
-
</body>
效果如图所示:
由图可知,因为全都存在于body根元素的BFC下,发生了重叠,若是想避免重叠,能够用另外一个BFC将第二个div包裹起来,能够本身试验一下。这里提一句,若是你直接将第二个div变成BFC(好比添加overflow:hidden),结果仍是同样的,由于他们两个仍是处于同一个BFC下。
第四条:浮动元素参与计算BFC高度
-
<div style="border: 3px solid #000;">
-
<div style="width: 50px; height: 50px; background: green;
-
float: left;">
-
</div>
-
</div>
效果如上,因为只是一个普通的div,里面包含的浮动元素并无为div撑起高度。尝试一下将div变成BFC看会发生什么。
第五条:BFC区域不会与float发生重叠。
咱们知道float是脱离文档流的,若是对其中一个div使用了float,两个并列的div会发生重叠,这时能够把非float的div变成BFC,这样就会避免重叠。
以上就是BFC的内容,要作到理解并运用到实际开发中。
下面说一下IFC,在这以前先看一个例子,这个是我在开发中遇到的问题,
-
.box{
-
width: 150px;
-
height: 150px;
-
display:inline-block;
-
word-wrap:break-word;
-
background:green
-
}
- <code class="language-css"><div class='box'>asdfasdfasdfffffffffffffffffffffffffffffffffffffffffffffffff</div>
- <div class='box'>asdfasdfasdf</div></code>
-
< div class=' box'> asdfasdfasdfffffffffffffffffffffffffffffffffffffffffffffffff</ div>
-
< div class=' box'> asdfasdfasdf</ div>
效果以下:
能够看到第二个inline-block发生了下陷,这里的知识就涉及到了IFC。这里也不卖关子,给第二个添加vertical-align:top;属性就能够解决问题。
首先说一下行级盒子的宽度和高度,能够很容易的发现,对<span>这个inline-level box设置宽度和高度并无什么做用(对于行内元素,设置margin,padding的top 和 bottom也是不起做用的),他有本身的宽高计算方法,高由font-size决定的,宽等于其子行级盒子的外宽度(margin+border+padding+content width)之和。
再说一下Inlinebox,总的来讲,inlinebox就是布局中的一行,里面能够只包含一个<span>行内元素,也能够包含多个<span>或者inline-block.
inlinebox也有本身的宽高度计算的方法,宽度取决于内部元素的宽度,最大为父元素的宽度,linebox的高度取决于linebox元素,通常由最高的元素决定linebox的高度。
这里我不对于BFC 作过多解释,若是想了解更深的,能够参照这篇文章,不过我却是以为若是不是太偏执,不须要这样,毕竟<span>嵌套<span>也许永远也不会用到这种操做。
要解决上面的问题,更多的应该关注行内元素的对齐方式,默认是baseline对其,来一张图;
因而可知,以前的对其方式为baseline对齐顾致使下陷。
下面总结几条inline元素的baseline位置:
- inline元素的baseline,为内容盒content-box里面文本框的基线。
- inline-block的外边缘就是margin-box的外边缘,
- 若是inline-block内部有内容,则baseline为内容最下方的baseline,参照刚才给出的例子。
- 若是Inline-block内部无内容,则baseline与margin-box的下边缘重合。
- 若是overflow属性不为visible(默认),则baseline与margin-box的下边缘重合。
这里给出一个例子作讲解,剩下的能够本身去尝试。
-
.box{
-
width: 150px;
-
height: 150px;
-
display:inline-block;
-
word-wrap:break-word;
-
background:green
-
}
-
.box1{
-
width: 150px;
-
height: 150px;
-
overflow:hidden;
-
display:inline-block;
-
word-wrap:break-word;
-
background:green
-
}
-
<div class='box1'>asdfasdfasdfffffffffffffffffffffffffffffffffffffffffffffffff </div>
-
<div class='box'>asdfasdfasdf </div>
执行结果以下,可见baseline与第一个inline-block的margin-box重合了。
IFC和BFC就介绍到这里,若是有问题欢迎提出指正。