前言:
  在非IE浏览器(如Firefox)下,当容器的高度为auto,且容器的内容中有浮动(float为left或right)的元素,在这种情况下,容器的高度不能自动伸长以适应内容的高度,使得内容溢出到容器外面而影响(甚至破坏)布局的现象,这个现象叫浮动溢出。为了防止这个现象的出现而进行的CSS处理,就叫CSS清除浮动。
  清除浮动主要是为了解决父元素因为子级元素浮动引起的内部高度塌陷的问题。

为什么会使用浮动?
  一开始出现浮动只是为了解决文字环绕图片问题,但最后是为了解决几个块级元素并排显示问题,虽然可以使用定义块级元素的display为inline-block(这种方式也不会出现父级元素坍塌问题)但是这种方式不能控制元素的位置而是默认从左到右,所以要实现元素是居左还是居右使用浮动更方便。但是使用了float之后不清除浮动就会出现父级高度塌陷问题。

实例:

  HTML代码基本代码

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>清除浮动</title><style>#parent{border: 1px solid black;}#child{width: 100px;height: 100px;background: red;float: left;}</style>
</head>
<body><div id="parent"><div id="child"></div></div>
</body>
</html>

  效果图-----未清除浮动

  效果图-----已清除浮动

  当为子元素设置了浮动,如果不清除浮动,那么父元素将会出现高度塌陷的现象。所以当我们设置了浮动后,就要解决浮动带来的影响。下面就要我们介绍几种清除浮动的方法!

方法一:额外标签法

  给谁清除浮动,就在其后额外添加一个空白标签 ,给其设置clear:both。

  优点:通俗易懂,书写方便。

  缺点:添加许多无意义的标签,结构化比较差。

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

  css样式

#clear{clear: both;
}

  html代码

<div id="parent"><div id="child"></div><!-- 方法一  额外标签法 --><div id="clear"></div>
</div>

方法二:父元素添加overflow:hidden

  通过触发BFC方式,实现清除浮动

  优点:代码简洁

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

  css样式

#parent{overflow: hidden;
}

方法三:使用after伪元素清除浮动

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

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

  css样式

#parent:after{content: "";display: block;height: 0;clear:both;visibility: hidden;
}
#parent{/* 触发 hasLayout */ *zoom: 1;/*ie6清除浮动的方式 *号只有IE6-IE7执行,其他浏览器不执行*/
}

方法四:使用before和after双伪元素清除浮动

  优点:代码更简洁

  缺点:用zoom:1触发hasLayout.

  css样式

#parent:after,#parent:before{content: "";
display: table;
}
#parent:after{clear: both;
}
#parent{*zoom: 1;
}

方法五:为父元素设置高度

  缺点: 需要手动添加高度,如何后面的高度发生变化,还要再次修改高度,给后期的维护带来麻烦。

  优点: 简单粗暴直接有效,清除了浮动带来的影响。

清除浮动的五种方法详解相关推荐

  1. H5清除浮动的五种方法

    引言:在HTML中,如果所有子元素发生了浮动,而父元素又未设置高度,则会发生高度坍塌为0,从而影响布局,因此要清除浮动,现跟大家分享五种方法:         方法一:给父元素添加高度 ,但企业开发中 ...

  2. 清除浮动的五种方法及优缺点

    我们首先要思考:为什么要清除浮动? 源代码: <!DOCTYPE html> <html> <head><meta charset="utf-8&q ...

  3. CSS清除浮动的五种方法(超详细)

    1.为什么要清除浮动? 浮动的原理是让图片脱离文档流,直接浮在桌面上.我们一般布局的时候都是只设置宽度不设置高度,让内容来自动填充高度.但使用浮动后会让原本填充的高度消失,父元素高度为0,后续添加内容 ...

  4. java构造和解析json_Java构造和解析Json数据的两种方法详解一

    在www.json.org上公布了很多JAVA下的json构造和解析工具,其中org.json和json-lib比较简单,两者使用上差不多但还是有些区别.下面首先介绍用json-lib构造和解析Jso ...

  5. java json解析 代码_Java构造和解析Json数据的两种方法详解一

    在www.json.org上公布了很多JAVA下的json构造和解析工具,其中org.json和json-lib比较简单,两者使用上差不多但还是有些区别.下面首先介绍用json-lib构造和解析Jso ...

  6. Java构造和解析Json数据的两种方法详解一

    在www.json.org上公布了很多JAVA下的json构造和解析工具,其中org.json和json-lib比较简单,两者使用上差不多但还是有些区别.下面首先介绍用json-lib构造和解析Jso ...

  7. java构建json_Java构造和解析Json数据的两种方法详解一

    在www.json.org上公布了很多JAVA下的json构造和解析工具,其中org.json和json-lib比较简单,两者使用上差不多但还是有些区别.下面首先介绍用json-lib构造和解析Jso ...

  8. 查看登陆系统用户的信息的三种方法详解

    查看登陆系统用户的信息的三种方法详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.who这个命令显示可以谁在登陆,但是这个有很多的花式玩法,这个命令超简单 语法:who [O ...

  9. 站长在线Python精讲:在Python中格式化字符串的两种方法详解

    欢迎你来到站长在线的站长学堂学习Python知识,本文学习的是<在Python中格式化字符串的两种方法详解>.本知识点主要内容有:使用%操作符格式化字符串和使用format()方法格式化字 ...

最新文章

  1. 网站关键词密度对SEO优化的重要性
  2. ASP.NET 访问共享文件夹
  3. 自定义拦截器和提供的拦截器
  4. hibernate mysql 映射_hibernate与mysql映射类型对应表与mysql导入导出
  5. android布局技巧:创建高效布局
  6. Visual Studio 2017的第五个更新包扩展了调试工具
  7. Java虚拟机-内存分配策略
  8. 【数字逻辑设计】毛刺
  9. 代码协定(三)——假定和断言
  10. 在前端团队的那些日子(初见)
  11. 使用BroadcastReceiver的Android IntentService
  12. 网络工程师Day1--实验1-4 配置三层交换
  13. lua : require' stn'
  14. 信号检测与估计理论pdf
  15. SysML建模工具学习笔记总结一
  16. 8类网线利弊_超6类7类8类网线进来挨打 6类线全面测评 网速和传输速率测试
  17. dialog第三方框架,material-dialogs的使用
  18. 23中设计模式之策略模式
  19. 两代人不同的求学之路
  20. 平板触控笔要原装的吗?开学季必备电容笔推荐

热门文章

  1. Tarjan模板 人工栈版Tarjan
  2. 前端开发常见笔试题(附答案)
  3. 吉利全球鹰熊猫CROSS
  4. ggplot绘制置信区间 与 分组绘图技巧
  5. 地图标识符号大全_微信小游戏大全:炮火荣耀!我再也不玩游戏了!
  6. 研究生带28岁腼腆导师一起相亲?被女生围追堵截要微信!
  7. 射影几何----射影坐标系下确定任一点的位置
  8. 【TensorFlow】神经网络中间层截取、可视化中间层结果
  9. 全球与中国集成平台即服务(iPaaS)软件市场现状及未来发展趋势
  10. ATH10传感器读取温湿度