美文网首页饥人谷技术博客
CSS学习笔记-清除浮动

CSS学习笔记-清除浮动

作者: _咸鱼君 | 来源:发表于2015-12-21 21:39 被阅读66次

前言

在工作中网页的布局基本使用float来处理,但是浮动所带来的副作用又是比较麻烦的一件事,今天写下这篇笔记📒来梳理一下。

正文

为什么要清除浮动

浮动:元素使用浮动之后会脱离文档流,左右移动直到浮动元素的外边缘碰到到他的父元素的边框或者碰到另一个浮动元素的边框,浮动的这个性质会影响网页的布局,例如:

  • 造成父元素的高度塌陷

当包含左列和右列的父元素的高度小于浮动的子元素时,父元素的高度没有被撑开。

  • 影响块级元素中的文本

对于黄色div来说,浮动的粉色div是不影响他的布局的,黄色div就像不存在粉色div一样呈现自己的布局,但是对于黄色div中的文字来说受到了浮动元素的影响。

因为浮动会造成以上之类的布局问题,所以在使用float之后,我们要清除浮动。

清除浮动的几种方法

  • 父元素也设置float:left。

这种方式比较简单,但是作为父容器来说设置了float同样会影响他相邻元素的布局,所以这种方法并不可取。

  • 浮动元素后面加一个任何标签然后样式设置clear:both;
<div id="content">
        <div class="left">左列,设置float:left</div>
        <div class="right">右列,设置float:left</div>
        <div class="clear"></div>
</div>
        #content{
            width:1000px;
            background:#ddd;
            border:3px solid red;
        }

        .left{
            float:left;
            width:300px;
            height:60px;
            background:pink;
        }

        .right{
            float:left;
            width:300px;
            height:60px;
            background:yellow;
        }

        .clear{
            clear:both;
        }

效果图:


这种方式同样是比较简单,但是缺点是增加了许多无意义的标签,不利于维护。

  • 浮动元素后面加一个<br clear="all" />

该方法与上一个浮动元素后面加一个任何标签然后样式设置clear:both类似,也产生无语义化的标签。

  • 包裹浮动元素的父元素使用overflow:hidden和overflow:auto
        #content{
            width:1000px;
            background:#ddd;
            border:3px solid red;
            overflow:hidden; //overflow:auto;
            *zoom:1;//IE6中出发hasLayout
        }

这种方法的优点是不存在语义化的问题,缺点是一些情况下可能会产生滚动条或者内容被隐藏了。

  • 使用after伪元素
        #content:after{
            content:"";
            display:block;
            clear:both;
        }

IE6中不支持after,可以使用

        #content{
            *zoom:1;//出发hasLayout
        }

这是目前采取的最常用的一种方法,相比以上有缺陷的几种做法,使用伪元素after比较保险。

结尾

几种清除浮动的方式具体情况具体分析,当包含浮动元素的父元素本身就有float或者overflow等需求设置时,可以不必采用伪元素等方式设置, 今天先到这里, 明天继续。

相关文章

  • CSS学习笔记-清除浮动

    前言 在工作中网页的布局基本使用float来处理,但是浮动所带来的副作用又是比较麻烦的一件事,今天写下这篇笔记?来...

  • CSS浮动续

    CSS清除浮动案例 CSS版心居中显示案例 清除浮动的四种用法: 1. 使用空标记清除浮动,隔墙法,增加标签 2....

  • CSS clear both清除浮动

    原文地址:CSS clear both清除浮动 DIV+CSS clear both清除产生浮动我们知道有时使用了...

  • 清除浮动

    一、清除浮动 or 闭合浮动 ? 清除浮动:清除对应的单词是 clear,对应CSS中的属性是 clear:lef...

  • 一篇文章带你了解CSS clear both清除浮动

    一、前言 CSS clear both清除产生浮动 ,使用了css float浮动会产生css浮动,这个时候就需要...

  • CSS笔记9:浮动&浮动清除

  • CSS 中的浮动

    浮动的定义: 元素脱离文档流 举栗子: 修改 CSS 代码,清除浮动: 浮动的影响: 父元素高度塌陷 清除浮动: ...

  • CSS浮动.清除浮动

    给父级元素设置高度 在底部添加一个空元素,清除浮动 父级div定义 overflow:hidden或者auto 为...

  • css浮动 清除浮动

    float : left | right | none 设计之初的作用是做文字环绕 p标签段落双标签块级 i...

  • Test10

    引用文章: 那些年我们一起清除过的浮动 CSS浮动float详解 Clear Float CSS float浮动的...

网友评论

    本文标题:CSS学习笔记-清除浮动

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