CSS清除浮动方法集合

一、浮动产生原因   -   TOP

一般浮动是什么情况呢?一般是一个盒子里使用了CSS float浮动属性,导致父级对象盒子不能被撑开,这样CSS float浮动就产生了。


浮动产生样式效果截图

本来两个黑色对象盒子是在红色盒子内,因为对两个黑色盒子使用了float浮动,所以两个黑色盒子产生了浮动,导致红色盒子不能撑开,这样浮动就产生了。

简单地说,浮动是因为使用了float:left或float:right或两者都是有了而产生的浮动。

二、浮动产生负作用   -   TOP

1、背景不能显示
由于浮动产生,如果对父级设置了(CSS background背景)CSS背景颜色或CSS背景图片,而父级不能被撑开,所以导致CSS背景不能显示。

2、边框不能撑开
如上图中,如果父级设置了CSS边框属性(css border),由于子级里使用了float属性,产生浮动,父级不能被撑开,导致边框不能随内容而被撑开。

3、margin padding设置值不能正确显示
由于浮动导致父级子级之间设置了css padding、css margin属性的值不能正确表达。特别是上下边的padding和margin不能正确显示。

三、css解决浮动,清除浮动方法   -   TOP

这里DIVCSS5为了统一讲解浮动解决方法,假设了有三个盒子对象,一个父级里包含了两个子级,子级一个使用了float:left属性,另外一个子级使用float:right属性。同时设置div css border,父级css边框颜色为红色,两个子级边框颜色为蓝色;父级CSS背景样式为黄色,两个子级背景为白色;父级css width宽度为400px,两个子级css宽度均为180px,两个子级再设置相同高度100px,父级css height高度暂不设置(通常为实际css布局时候这样父级都不设置高度,而高度是随内容增加自适应高度)。

父级CSS命名为“.divcss5”对应html标签使用“<div class="divcss5">”
两个子级CSS命名分别为“.divcss5-left”“.divcss5-right”

根据以上描述DIVCSS5给出对应CSS代码和HTML代码片段

CSS代码:

  1. .divcss5{ width:400px; border:1px solid #F00; background:#FF0}
  2. .divcss5-left,.divcss5-right{ width:180px; height:100px;
  3. border:1px solid #00F; background:#FFF}
  4. .divcss5-left{ float:left}
  5. .divcss5-right{ float:right}

对应html源代码片段:

  1. <div class="divcss5">
  2. <div class="divcss5-left">left浮动</div>
  3. <div class="divcss5-right">right浮动</div>
  4. </div>


清除浮动前案例截图父级需要清除浮动

以下DIVCSS5总结了几点用于清除浮动的经验教程

1、对父级设置适合CSS高度
对父级设置适合高度样式清除浮动,这里对“.divcss5”设置一定高度即可,一般设置高度需要能确定内容高度才能设置。这里我们知道内容高度是100PX+上下边框为2px,这样具体父级高度为102px

CSS代码:

  1. .divcss5{ width:400px;border:1px solid #F00;background:#FF0; height:102px}
  2. .divcss5-left,.divcss5-right{width:180px;height:100px;
  3. border:1px solid #00F;background:#FFF}
  4. .divcss5-left{ float:left}
  5. .divcss5-right{ float:right}

Html代码不变。得到截图


使用height高度清除浮动

小结,使用设置高度样式,清除浮动产生,前提是对象内容高度要能确定并能计算好。

2、clear:both清除浮动
为了统一样式,我们新建一个样式选择器CSS命名为“.clear”,并且对应选择器样式为“clear:both”,然后我们在父级“</div>”结束前加此div引入“class="clear"”样式。这样即可清除浮动。

具体CSS代码:

  1. .divcss5{ width:400px;border:1px solid #F00;background:#FF0}
  2. .divcss5-left,.divcss5-right{width:180px;height:100px;
  3. border:1px solid #00F;background:#FFF}
  4. .divcss5-left{ float:left}
  5. .divcss5-right{ float:right}
  6. .clear{ clear:both}

Html代码:

  1. <div class="divcss5">
  2. <div class="divcss5-left">left浮动</div>
  3. <div class="divcss5-right">right浮动</div>
  4. <div class="clear"></div> 
  5. </div>

clear清除浮动截图


clear清除浮动截图 使用CSS clear清除浮动

这个css clear清除float产生浮动,可以不用对父级设置高度 也无需技术父级高度,方便适用,但会多加CSS和HTML标签。

3、父级div定义 overflow:hidden
对父级CSS选择器加overflow:hidden样式,可以清除父级内使用float产生浮动。优点是可以很少CSS代码即可解决浮动产生。

overflow:hidden解决CSS代码:

  1. .divcss5{ width:400px;border:1px solid #F00;background:#FF0; overflow:hidden}
  2. .divcss5-left,.divcss5-right{width:180px;height:100px;
    border:1px solid #00F;background:#FFF}
  3. .divcss5-left{ float:left}
  4. .divcss5-right{ float:right}

HTML代码不变。

解决清除浮动后截图


overflow清除float产生浮动截图 overflow:hidden清除浮动截图

为什么加入overflow:hidden即可清除浮动呢?那是因为overflow:hidden属性相当于是让父级紧贴内容,这样即可紧贴其对象内内容(包括使用float的div盒子),从而实现了清除浮动。Css overflow:hidden清除浮动方法DIVCSS5推荐使用。

以上三点即是兼容各大浏览器清除浮动的方法,其它有的浏览器不兼容有的不兼容的方法就没必要介绍了,大家记住以上三点解决float浮动清除浮动方法。但这里推荐第三点和第二点解决清除浮动方法。

如需转载,请注明文章出处和来源网址:http://www.divcss5.com/jiqiao/j406.shtml

转载于:https://www.cnblogs.com/zhangjianqiang/articles/7272150.html

CSS清除浮动_清除float浮动相关推荐

  1. CSS中的趣事之float浮动

       浮动float一般跟left或是right: 特性: 1,包裹性:浮动文本类型时,需要指定宽度width,如果不指定,就会折叠到最小宽度: 2,浮动会影响别的元素: 3,子级浮动,会导致父级高度 ...

  2. 卸载后的mysql和navicat怎么清除干净_清除电脑“牛皮癣 ”,带你回归清爽体验~...

    前言:相信大家对存在电脑中的各类垃圾软件(弹窗)深恶痛绝,这不仅影响了我们电脑使用的体验感受,更重要的是那些"牛皮癣 "还会严重的影响我们电脑的运行性能和安全性.前面有跟大家分享过 ...

  3. css选择器及float(浮动)

    --------------------------选择器( css有就近原则)------------------------------- 选择器名称                 在css表的 ...

  4. CSS样式 float浮动用法

    CSS样式 float浮动用法 前言 Css样式的float浮动属性,用于设置标签对象(如:<div>标签盒子.<span>标签.<a>标签.<em>标 ...

  5. css(float浮动和clear清除)

      教程开始: 首先要知道,div是块级元素,在页面中独占一行,自上而下排列,也就是传说中的流.如下图: 可以看出,即使div1的宽度很小,页面中一行可以容下div1和div2,div2也不会排在di ...

  6. CSS:盒子模型和清除float浮动的三种常用方法

    目录 一:浮动产生原因: 二:浮动产生副作用: 三:浮动解决方法: QUESTION:CSS盒子模型清除浮动? ANSWER: 一:浮动产生原因: 一般浮动是什么情况呢?一般是一个盒子里使用了CSS ...

  7. CSS清除浮动 清除float浮动

    一般浮动是什么情况呢?一般是一个盒子里使用了CSS float浮动属性,导致父级 对象盒子不能被撑开,这样CSS float浮动就产生了. 1.背景不能显示 由于浮动产生,如果对父级设置了(CSS b ...

  8. 前端笔记(6)css布局机制,浮动,清除浮动,图片格式,ps切片工具及插件

    css样式表/层叠样式表(4) css布局的三种机制 浮动 浮动(float)的扩展 清除浮动 额外标签法(隔墙法) 父级添加overflow属性方法 使用after伪元素清除浮动 使用双伪元素清除浮 ...

  9. css盒子模型、文档流、相对与绝对定位、浮动与清除模型

    一.CSS中的盒子模型 标准模式和混杂模式(IE).在标准模式下浏览器按照规范呈现页面:在混杂模式下,页面以一种比较宽松的向后兼容的方式显示.混杂模式通常模拟老式浏览器的行为以防止老站点无法工作. h ...

最新文章

  1. python开发工具
  2. 征途堆积出友情的永恒「堆优化dp」
  3. ALV报表中设置可修改字段
  4. jenkins 调用通知接口返回build信息
  5. SAP Engagement Center的ShellCarousel控件control
  6. 03 渲染元素ReactDOM.render
  7. 常见Java开发过程中遇到的问题及其解决办法
  8. 推荐两个在线格式化JavaScript代码的网站
  9. 简练软考知识点整理-互联网+
  10. python 多行字符串缩进_Python多行字符串的正确缩进
  11. css中iconfont图标旋转
  12. U盘PE系统的制作和安装(win7、win10)
  13. c语言第十章函数课后作业,c语言函数练习题附答案.doc
  14. Lua 求表中元素的最大值和最小值
  15. 流行购车平台易车买车划算吗?
  16. 佩尔(Pell)方程最小正整数解
  17. 麒麟linux代码行界面颜色,查看“麒麟”的源代码
  18. 3个精美漂亮的wordpress律师网站模板
  19. 华为内部实施微服务架构
  20. 高德地图API实现天气查询

热门文章

  1. 巧妙设置Android来方便管理Linux和Windows
  2. [4月21日]《51CTO 编辑部的外传》——剧本篇(上)
  3. 前工404见闻,让我怀疑我是不是身处东南大学……
  4. win10系统80端口被System (PID=4)占用的解决
  5. 【转】gcc 编译使用动态链接库和静态链接库
  6. CodeForces - 993E Nikita and Order Statistics
  7. maven添加oracle jdbc依赖
  8. IOS-开发中手势的处理
  9. Java的多线程问题追根溯源。
  10. Android Handler 流程解析