美文网首页
Css中的float和BFC(Block Formatting

Css中的float和BFC(Block Formatting

作者: 柴犬_ | 来源:发表于2016-09-20 20:45 被阅读0次

css中的float(浮动):

在css中浮动的作用可让元素脱离文档流,从而达到某种布局效果

  • float:left,可以让元素向左浮动,元素会浮动到父元素的左边缘,由于脱离了文档流,所以处于正常文档流内的元素会后来居上,相应的浮动元素会盖在位于它之后,且和它处于同一父元素内的元素上面。
    <pre>
    <code><div class="container"></code>
    <code><div class="elem-1"></div></code>
    <code><div class="elem-2"></div></code>
    <code><div class="elem-3"></div></code>
    <code></div></code>
    </pre><pre>// float 1
    .container {
    border: 3px solid blue;
    padding: 10px;
    }
    .elem-1 {
    width: 80px;
    height: 80px;
    background-color: green;
    }
    .elem-2 {
    width: 100px;
    height: 100px;
    background-color: yellow;
    }
    .elem-3 {
    width: 120px;
    height: 120px;
    background-color: red;
    }
    // float 2
    .elem-1 {
    width: 80px;
    height: 80px;
    float: left;
    background-color: green;
    }
    </pre>
    当我给elem-1加上float:left之后,elem-1脱离文档流,且浮动于elem-2之上
    float-1 添加float之前.png
    float-2 加上float之后.png
    如果我给所有elem都加上float:left之后,它们都会脱离文档流,且会按照浮动方向依次排列,一个元素内部所有子元素都处于浮动状态时,父元素会出现塌陷的情况,也就是身体被掏空
    <pre>// float 3
    .elem-2 {
    width: 100px;
    height: 100px;
    float: left;
    background-color: yellow;
    }
    .elem-3 {
    width: 120px;
    height: 120px;
    float: left;
    background-color: red;
    }
    </pre>
    float-3.png
    但注意到元素float:left之后,虽然脱离文档流,但还是会浮动到content的边缘,并不会超出padding
  • 浮动的结果
    元素的浮动会在页面布局的过程中很方便,但造成的影响有时也会让人很头疼,元素塌陷就是其中一个弊端。
    由上面的例子可以看出,元素的浮动,会影响到其后相邻的元素(elem1浮动于elem2上,盖住了elem2的内容),同时浮动会造成的一个结果就是<u>产生一个BFC的context</u>, 这个我们之后在继续说明BFC是个什么鬼
  • 清除浮动
    为了处理由于用了浮动,一时开心而埋下的隐患,你就必须得知道清除浮动的一些方法。
    常用的一些方法有
  1. 在其相邻元素上加上<code>clear:left/right/both;</code>这个css样式,
    <pre>
    <div class="container">
    <code> ...</code>
    <code> ...</code>
    <code> ...</code>
    <code> <div class="elem-4" style="clear:left"></div></code>
    </div>
    </pre>
    这种清除浮动的方式很容易理解,浮动会给紧邻的元素造成布局影响,那我在它的紧邻元素上清除掉浮动就好了
    float-4.png
    所以这样,浮动造成的塌陷问题就被解决了,同时,内部的浮动元素还能享受到浮动带来的不一样的横向block排列方式,而不用你去设置<code>display: inline-block;</code>这个属性了,而且inline-block 的设置会有个小缺陷,并排的行内块级元素中间会有大约4px的间距,所以通常又需要<code>margin-right: -4px;</code>来解决这一问题,并不是特别方便,而浮动能帮你轻易的实现这种布局效果
  2. 在浮动元素的父元素上添加伪元素清除浮动
    <pre>
    .container:after {
    content: '';
    display: table;
    clear: both;
    }
    </pre>
    这种方法相比较上一种添加一个没太大意义的html元素来说更合理一些,它采用给父元素加伪类的方法来清除子元素浮动带来的布局影响,同样能够达到图float-4的效果,这里需要注意的有两点,1⃣️ content,是伪元素中必须的一个属性,但你可以设一个空值。2⃣️ display的设置,display可以设置成block也可以设制成table,都会有清除浮动的效果,但通常情况下都会设置table,因为相比block,table不容易影响其他页面元素的布局。

上述两种方法都是比较常规的利用clear属性来清除浮动的不同做法,但清除浮动还有的一种做法是构造一个BFC(Block Formatting Context)容器,听起来似乎会比较麻烦,好像很难的样子,但实际并非如此,在下一节会给大家做BFC的介绍,以及用它清除浮动的办法。

相关文章

  • Css中的float和BFC(Block Formatting

    css中的float(浮动): 在css中浮动的作用可让元素脱离文档流,从而达到某种布局效果 float:left...

  • CSS清除浮动的方法

    BFC CSS中的BFC BFC:block formatting context块级格式化上下文; BFC 与清...

  • CSS-BFC的理解

    简介在使用CSS的过程中,经常会听到触发BFC,但是何为BFC。BFC(Block formatting cont...

  • 快速弄懂 BFC

    参考 BFC 是什么 css 2.1 规范。BFC(Block formatting context)直译为"块级...

  • Day13:H5+JS+C3

    css布局中,什么是BFC BFC是Block formatting context的缩写,表示“块级格式化上下文...

  • BFC

    BFC定义 BFC 全称 Block Formatting Context。BFC(Block formattin...

  • 【CSS古话今说】-- 01.神奇的CSS-BFC在实战中的应用

    文章首发于掘金 BFC(Block Formatting Context)是Web页面中盒模型布局的CSS渲染模式...

  • BFC原理解析

    BFC BFC(Block Formatting Contexts),块级格式化上下文 盒模型 CSS盒模型描述了...

  • 对 BFC 的理解

    BFC (Block Formatting Context) 是 CSS 中的一个概念,用于解决布局问题。它是一个...

  • CSS新手向学习总结

    关于BFC BFC(block formatting context)即块格式上下文,是Web页面的可视化CSS渲...

网友评论

      本文标题:Css中的float和BFC(Block Formatting

      本文链接:https://www.haomeiwen.com/subject/bvpoettx.html