css清除浮动的四种方法(详细)

css清除浮动的四种方法(详细)css 清除浮动的四种方式

浮动带来的影响

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

看下面一段代码

<div class="fater"> <div class="box1">one</div> <div class="box2">two</div> </div> <div class="box3">three</div> .fater { 
    width: 300px; /* background-color: aquamarine; */ border: 1px solid pink; } .box1 { 
    width: 100px; height: 100px; background-color: blue; float: left; } .box2 { 
    width: 150px; height: 120px; background-color: blueviolet; float: left; } .box3 { 
    width: 200px; height: 150px; background-color: brown; } 

在这里插入图片描述
此时因为盒子1和2浮动,脱离文档流,那么在他们下面的盒子就会顶上来,又因为父盒子没有设置高度,此时父盒子的高度为零,浮动的元素不能撑开父盒子的高度因为因为子元素脱离文档流,父元素不脱离文档流,此时父盒子相当于没有元素所以高度为零
这样浮动带来的影响我们可以通过几种方法进行处理




1.在浮动元素后面添加一个标签 (不推荐使用)

缺点:增加无用标签,缺少语义化

在这里插入图片描述
在这里插入图片描述

这时候浮动已经清除了,意思就是在两个浮动元素后面加一个块级元素,添加clear属性

clear属性有三个值

left 清除前面的左浮动元素带给我的影响
right 清除前面的右浮动元素带给我的影响
both 同时清除前面的左右浮动元素带给我的影响. 一般情况下选择这个值比较方便.
clear 属性的原理就是给这个标签,添加 margin-top 让该元素的上外边距与浮动元素高度最高的相等, 此父盒子的高度就会被撑开,当然你也不在标签里面添加任何内容,这里只是方便展示效果
在这里插入图片描述
在这里插入图片描述










2.给父盒子添加 overflow: hidden(触发BFC) 不推荐使用

定义:BFC(Block Formatting Context)全称是块级格式化上下文,用于对块级元素排版,默认情况下只有根元素(body)一个块级上下文,但是如果一个块级元素设置了float:left,overflow:hidden或position:absolute样式,就会为这个块级元素生产一个独立的块级上下文,使这个块级元素内部的排版完全独立

作用:独立的块级上下文可以包裹浮动流,全部浮动子元素也不会引起容器高度塌陷,就是说包含块会把浮动元素的高度也计算在内,所以就不用清除浮动来撑起包含块的高度。

那什么时候会触发 BFC 呢?常见的情况如下:

• 根元素;

• float的值不为none;

• overflow的值为auto、scroll或hidden;

• display的值为table-cell、table-caption和inline-block中的任何一个;

• position的值不为relative和static。

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

在这里插入图片描述
效果
在这里插入图片描述
浮动已经清除了 它的原理和第一次差不多,只不过利用位伪元素没有添加实质的标签,是代码更具有语义化
优点:符合闭合浮动思想,结构语义化正确
缺点:ie6-7不支持伪元素:after,使用zoom:1触发hasLayout.










 .clearfix{ 
    *zoom: 1;/*ie6清除浮动的方式 *号只有IE6-IE7执行,其他浏览器不执行*/ } 
4.使用before和after双伪元素清除浮动

在这里插入图片描述
效果跟第三种方式是一样的!!!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/220132.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 下午9:10
下一篇 2026年3月17日 下午9:10


相关推荐

  • 使用exceljs导出excel表格

    使用exceljs导出excel表格背景最近在使用 electon 写一个桌面程序 需要对数据进行 excel 导出操作 这里选择使用 exceljs 来完成这个功能 下面是 exceljs 导出功能的简单实现 功能实现下载 exceljsyarna 引入 exceljsconst require exceljs 创建工作簿并设置工作簿属性 constworkboo newExcelJS Workbook workbook creator Me workbook l

    2026年3月18日
    2
  • sql Server配置管理器[通俗易懂]

    sql Server配置管理器[通俗易懂]一个是书里的,一个是我的,对比一下一:管理SQLServer2008服务开始—-所有程序—-MicrosoftSQLServer2008R2—-配置工具—-SQL Server配置管理器  …

    2022年7月21日
    13
  • js循环输出div

    js循环输出divbody 部分 div 点我 divdiv divjs 代码 scriptsrc jquery1 4 2 js type text javascript scriptscript function div first click function div last after div

    2026年3月19日
    2
  • 连不上docker mysql_docker跨主机通信

    连不上docker mysql_docker跨主机通信宿主机连接docker中的mysqldokcer安装mysqldockerrun\–namemysql\-v$PWD/mysql:/var/lib/mysql\-p3306:3306\-eMYSQL_ROOT_PASSWORD=123456\-dmysql:5.7宿主机连接docker中的mysql错误的连接方式$mysql-uroot-pEnterpasswor…

    2022年8月21日
    8
  • linux修改用户名命令6,linux用命令改用户名

    linux修改用户名命令6,linux用命令改用户名怎样更改linux的用户名Linux中可以使用usermod命令更改用户名,具体的操作方法如下:首先打开linux的终端,输入指令修改用户名,简单的用户名修改是usermod加参数l,后面跟新用户名,最后是旧用户名。此时用cd命令来到home目录,会发现存在一点小问题。linux下命令怎么修改用户名先用终端进入到根目录下的root文件夹然后su权限不用我说了吧然后用下面这个命令:usermo…

    2026年1月14日
    5
  • VS2013+uCOSII V2.91(uCOSII移植)

    VS2013+uCOSII V2.91(uCOSII移植)最近在看任哲的 嵌入式实时操作系统原理及应用 看了前面 8 章 虽然能看懂书上的代码 但因为没有动手写过 心里没有底 所以还是得动手写点代码测试 书上推荐的是 BorlandC3 1 但因为 Win10 不知道什么原因 安装不了 就放弃了 uCOSII 既然是用 C 写的可移植实时操作系统 能不能移植到 PC 上用 VS 编译呢 于是就在网上搜索了一下 果然有前辈开路 下面开始讲述怎么把 uCOSII 移植到 VS20

    2026年3月8日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号