美文网首页饥人谷技术博客
# 清除浮动的几种有效方法

# 清除浮动的几种有效方法

作者: 我叫小麦0708 | 来源:发表于2018-01-20 11:49 被阅读0次

浮动的定义:

浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止。
由于浮动框不在文档的普通流中,所以文档的普通流中的块框表现得就像浮动框不存在一样。
浮动是CSS布局中最常用的属性,然而浮动是脱离文档流的,如果不清除浮动的话,会对周围的元素产生影响。

   .content {
      width: 300px;
      border: 2px solid;
    }
    .aside {
      width: 100px;
      background: red;
      height: 100px;
      float: left;
    }
    .main {
      width: 100px;
      height: 100px;
      background: blue;
      float: right;
    }
  </style>
<body>
  <div class="content">
    <div class="aside">左浮动</div>
    <div class="main">右浮动</div>
  </div>
</body>
浮动浮动

块级元素添加浮动后,父元素没有发现,导致无法把父元素撑开,使父元素塌陷

清除浮动的方法

一. 添加空标签

在两个块级元素main下方添加一个div空标签,在其元素的style中添加clear属性:clear:both;

<style>
.box {
      clear: both;
    }
</style>
<body>
  <div class="content">
    <div class="aside">左浮动</div>
    <div class="main">右浮动</div>
    <div class="box">无浮动</div>
  </div>
</body>

添加一个空标签后,去除左右浮动后,父元素可以发现这个普通流,父元素被这个空标签给撑开了
缺点:添加一个无意义的标签,影响整体美观性

二. 父元素定义overflow:hidden

添加overflow:hidden后,是父元素高度固定,超出固定高度后就会溢出隐藏

<style>
.content {
      overflow: hidden;
    }
</style>
<body>
  <div class="content">
    <div class="aside">左浮动</div>
    <div class="main">右浮动</div>
  </div>
</body>

overflow:hidden与overflow:auto相对应
缺点:不能和position配合使用,因为超出的尺寸的会被隐藏

三. 父元素定义伪元素:after

为了兼容IE6,7使用需要在父元素的样式中添加zoom: 1;添加zoom: 1;后会触发浏览器的haslayout属性,来达到类似清除浮动的效果。

<style>
    .content {
      *zoom: 1;
    }
   .content::after {
      content: '';
      display: block;
      clear: both;
    }
  </style>

content是在块级标签后增加内容,添加的标签为行内元素,使用display:block;变为块级元素并清除左右的浮动,从而达到了清除浮动的效果。

以上是目前常用的三种方法,其中父元素定义伪元素:after的方法最优,另外还有其实清除浮动的方法,例如:使用定位position: absolute;、使父元素成为浮动float: left;则不需要清除浮动等方法。

相关文章

  • # 清除浮动的几种有效方法

    浮动的定义: 浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止。由于浮动框不在文档的普...

  • 清除浮动的最佳方法

    清除浮动的几种方法,这里不一一列举 个人认为,使用伪类来清除浮动是最好的一种方法 1) display:block...

  • 清除浮动常用的几种解决方法

    关于清除浮动的几种解决方法 一、浮动产生原因 浮动的产生是因为使用了float:left或float:rig...

  • css清除浮动

    前端开发中浮动处处可见,本文探讨浮动的成因以及如何更加有效的清除浮动。 1、浮动与清除浮动 2、清除浮动 基本cs...

  • 清除浮动的几种方法

    清除浮动的目的: 解决高度塌陷。 方法 clear: both 1.0 clear: both 2.0 注意只能使...

  • 清除浮动的几种方法

    1.clear:both 2.overflow:hidden(原意是溢出隐藏) 3.给内容加高度

  • 清除浮动的几种方法

    1.给父级元素添加clearfix名,使用after伪类清除浮动 2.在浮动元素后添加一个元素 3.给浮动元素父级...

  • 清除浮动的几种方法

    父元素使用伪元素after(推荐) 给浮动元素后的同级块级元素设置样式 clear: both 缺点:需要添加无用...

  • 清除浮动的几种方法

    面试又被问到了清浮动啊,一下子没答全,了解的也不是很透彻。再来总结一下! 为什么要清除浮动 因为浮动会使当前标签脱...

  • 清除浮动的几种常用方法

    CSS中的浮动简单介绍 浮动是CSS中的一个属性float来实现的,通过设置属性值left、right来实现元素的...

网友评论

    本文标题:# 清除浮动的几种有效方法

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