zoukankan      html  css  js  c++  java
  • 【CSS】清浮动的常用四种方法

    前言:

    为什么要清除浮动?

    清除浮动主要是为了解决,父元素因为子级元素浮动引起的内部高度为0的问题

    1.如下,我给父盒子设置一个boder,内部放两个盒子一个big 一个small,未给big和small设置浮动,则他们会默认撑开父盒子

     

    2.当我给内部两个盒子加上float属性的时候

     

    顶部深蓝色盒子就会顶上来,然后父盒子因为没设置高度,变成一条线,big和small已经浮动了

    总结:

    当父元素不给高度的时候,

    内部元素不浮动时会撑开

    而浮动的时候,父元素变成一条线

    清除浮动的方法(最常用的4种)
    1.额外标签法(在最后一个浮动标签后,新加一个标签,给其设置clear:both;)(不推荐)

    <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
    .fahter{
    width: 400px;
    border: 1px solid deeppink;
    }
    .big{
    width: 200px;
    height: 200px;
    background: darkorange;
    float: left;
    }
    .small{
    width: 120px;
    height: 120px;
    background: darkmagenta;
    float: left;
    }
    .footer{
    width: 900px;
    height: 100px;
    background: darkslateblue;
    }
    .clear{
    clear:both;
    }
    </style>
    </head>
    <body>
    <div class="fahter">
    <div class="big">big</div>
    <div class="small">small</div>
    <div class="clear">额外标签法</div>
    </div>
    <div class="footer"></div>
    </body>
    </html>

    显示效果没问题

    注:clear:both:本质就是闭合浮动, 就是让父盒子闭合出口和入口,不让子盒子出来

    如果我们清除了浮动,父元素自动检测子盒子最高的高度,然后与其同高。

    优点:通俗易懂,方便

    缺点:添加无意义标签,语义化差

    不建议使用。

    2.父级添加overflow属性(父元素添加overflow:hidden)(不推荐)

    通过触发BFC(overflow: hidden)方式,实现清除浮动

    .fahter{
     400px;
    border: 1px solid deeppink;
    overflow: hidden;//清浮动
    }


    优点:代码简洁

    缺点:内容增多的时候容易造成不会自动换行导致内容被隐藏掉,无法显示要溢出的元素

    不推荐使用

    注:

    BFC:

    块格式化上下文(Block Formatting Context,BFC) 是Web页面的可视化CSS渲染的一部分,是块盒子的布局过程发生的区域,也是浮动元素与其他元素交互的区域。

    下列方式会创建块格式化上下文:

    • 根元素或包含根元素的元素
    • 浮动元素(元素的 float不是 none
    • 绝对定位元素(元素的 position为absolutefixed`)
    • 行内块元素(元素的 displayinline-block
    • 表格单元格(元素的 displaytable-cell,HTML表格单元格默认为该值)
    • 表格标题(元素的 displaytable-caption,HTML表格标题默认为该值)
    • 匿名表格单元格元素(元素的 displaytable、``table-rowtable-row-group、``table-header-group、``table-footer-group(分别是HTML table、row、tbody、thead、tfoot的默认属性)或 inline-table
    • overflow值不为 visible 的块元素
    • display值为 flow-root 的元素
    • contain值为 layoutcontentstrict 的元素
    • 弹性元素(displayflexinline-flex元素的直接子元素)
    • 网格元素(displaygridinline-grid 元素的直接子元素)
    • 多列容器(元素的 column-countcolumn-width不为 auto,包括 column-count1
    • column-spanall 的元素始终会创建一个新的BFC,即使该元素没有包裹在一个多列容器中.
    • 块格式化上下文包含创建它的元素内部的所有内容.

    • 块格式化上下文对浮动定位与清除浮动都很重要。浮动定位和清除浮动时只会应用于同一个BFC内的元素。浮动不会影响其它BFC中元素的布局,而清除浮动只能清除同一BFC中在它前面的元素的浮动。外边距折叠(Margin collapsing)也只会发生在属于同一BFC的块级元素之间。

    • 设置 overflow: auto 创建一个新的BFC来包含这个浮动。我们的 <div> 元素现在变成布局中的迷你布局。任何子元素都会被包含进去。

    • 使用 overflow 来创建一个新的BFC,是因为 overflow 属性告诉浏览器你想要怎样处理溢出的内容。当你使用这个属性只是为了创建BFC的时候,你可能会发现一些不想要的问题,比如滚动条或者一些剪切的阴影,需要注意。另外,对于后续的开发,可能不是很清楚当时为什么使用overflow。所以你最好添加一些注释来解释为什么这样做。

    3.使用after伪元素清除浮动(推荐使用)

    .clearfix:after{/*伪元素是行内元素 正常浏览器清除浮动方法*/
    content: "";
    display: block;
    height: 0;
    clear:both;
    visibility: hidden;
    }
    .clearfix{
    *zoom: 1;/*ie6清除浮动的方式 *号只有IE6-IE7执行,其他浏览器不执行*/
    }
    
    <body>
    <div class="fahter clearfix">
    <div class="big">big</div>
    <div class="small">small</div>
    <!--<div class="clear">额外标签法</div>-->
    </div>
    <div class="footer"></div>
    </body>


    优点:符合闭合浮动思想,结构语义化正确

    缺点:ie6-7不支持伪元素:after,使用zoom:1触发hasLayout.

    推荐使用

    4.使用before和after双伪元素清除浮动

    .clearfix:after,.clearfix:before{
    content: "";
    display: table;
    }
    .clearfix:after{
    clear: both;
    }
    .clearfix{
    *zoom: 1;
    }
    
    <div class="fahter clearfix">
    <div class="big">big</div>
    <div class="small">small</div>
    </div>
    <div class="footer"></div>


    优点:代码更简洁

    缺点:用zoom:1触发hasLayout.

    推荐使用


    注:后两种方法的content:"." 里面尽量跟一个小点,或者其他,尽量不要为空,否则再firefox 7.0前的版本会有生成空格。

  • 相关阅读:
    ansible-handlers
    LNMP
    编译安装sshpass
    cadence-irun(xrun) 增量编译
    sva 基础语法
    bsub && lsf 介绍
    Perl 输出内容到 excel
    Perl sendmail
    dlopen与dlsym用法
    perl在linux下通过date获取当前时间
  • 原文地址:https://www.cnblogs.com/shijianblog/p/12564361.html
Copyright © 2011-2022 走看看