设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 重新 试卷 文件
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

理解CSS布局和BFC,真正提高你的CSS布局能力(2)

发布时间:2019-04-03 20:50 所属栏目:21 来源:前端小智
导读:因为 p 元素的 margin 和外部 div 上的 margin 之间没有任何东西,所以两个会折叠,因此 p 最终与 div 的顶部和底部齐平。 我们在 p 的上方和下方看不到任何灰色。 在CSS当中,相邻的两个盒子(可能是兄弟关系也可

因为 p 元素的 margin 和外部 div 上的 margin 之间没有任何东西,所以两个会折叠,因此 p 最终与 div 的顶部和底部齐平。 我们在 p 的上方和下方看不到任何灰色。

在CSS当中,相邻的两个盒子(可能是兄弟关系也可能是祖先关系)的外边距可以结合成一个单独的外边距。这种合并外边距的方式被称为折叠,并且因而所结合成的外边距称为折叠外边距。折叠的结果按照如下规则计算:

  1.  两个相邻的外边距都是正数时,折叠结果是它们两者之间较大的值。
  2.  两个相邻的外边距都是负数时,折叠结果是两者绝对值的较大值。
  3.  两个外边距一正一负时,折叠结果是两者的相加的和。

产生折叠的必备条件:margin必须是邻接的!

如果我们把盒子设为 BFC,它现在包含了标签 p 和它们的边距,这样它们就不会折叠,我们可以看到边距后面容器的灰色背景。

  1. .outer {  
  2.   background-color: #ccc;  
  3.   margin: 0 0 40px 0;  
  4.   overflow: auto;  

查看演示

再一次,BFC 的工作是把东西装在盒子里,防止它们从盒子里跑出来。

BFC 可以阻止元素被浮动元素覆盖

你将熟悉 BFC 的这种行为,因为使用浮动的任何列类型布局都是这样工作的。如果一个项目创建了一个 BFC,那么该项目将不会包裹任何浮动元素。在下面的例子中,有如下 html 结构:

  1. <div class="outer"> 
  2.   <div class="float">I am a floated element.</div>  
  3.   <div class="text">I am text</div>  
  4. </div> 

带有 float 类的项被向左浮动,因此 div 中的文本在它环绕 float 之后。

我可以通过将包裹文本的 div 设置为 BFC 来防止这种包裹行为。

  1. .text {  
  2.   overflow: auto;  

这实际上是我们创建具有多个列的浮动布局的方法。浮动项还为该项创建了一个 BFC,因此,如果右边的列比左边的列高,那么我们的列就不会相互环绕。

查看演示

在多列布局中使用 BFC

如果我们创建一个占满整个容器宽度的多列布局,在某些浏览器中最后一列有时候会掉到下一行。这可能是因为浏览器四舍五入了列宽从而所有列的总宽度会超出容器。但如果我们在多列布局中的最后一列里创建一个新的BFC,它将总是占据其他列先占位完毕后剩下的空间。

例如:

  1. <div class="container">  
  2.     <div class="column">column 1</div>  
  3.     <div class="column">column 2</div>  
  4.     <div class="column">column 3</div>  
  5. </div> 

对应的CSS:

  1. .column {  
  2.     width: 31.33%;  
  3.     background-color: green;  
  4.     float: left;  
  5.     margin: 0 1%;  
  6. }  
  7. .column:last-child {  
  8.   float: none;  

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读