为什么要清除浮动以及清除浮动的方法

本文详细介绍了为什么需要清除浮动以及四种有效的清除浮动方法:设置固定高度、使用clear:both、利用伪元素和br标签。通过实例解释了如何避免父元素塌陷,保持页面布局稳定。

1.为什么要清除浮动

浮动元素会脱离文档流,导致父元素塌陷;举个例子:一个橡皮筋绑了10根筷子,此时橡皮筋就被撑开;当把筷子从橡皮筋中拿出来时,橡皮筋就变回原样。这样当话,父元素中如果有背景图片或是其他样式,就会受到影响。

2.清除浮动的方法

a.给父元素设置固定的高度

b.clear:both

在最后一个子元素的后面添加一个块级元素,然后将其设置clear:both,这样就可以清除浮动

<div id="wrap">
    <div id="inner"></div>
    <div style="clear: both;"></div>
</div>
#wrap{
      border: 1px solid;
}
#inner{
      float: left;
      width: 200px;
      height: 200px;
      background: pink;
}
复制代码

c.伪元素清除浮动

其实和第二种方法一样,只是第二种方法会添加一个冗余元素;使用:after在浮动元素的父容器后添加一个看不见的块级元素,设置为clear:both;

<div id="wrap" class="clearfix">
  <div id="inner"></div>
</div>

  #wrap {
    border: 1px solid;
  }
  #inner {
    float: left;
    width: 200px;
    height: 200px;
    background: pink;
  }
  /*开启haslayout*/
  .clearfix {
    *zoom: 1;
  }
  /*ie6 7 不支持伪元素*/
  .clearfix:after {
    content: '';
    display: block;
    clear: both;
    height:0;
    line-height:0;
    visibility:hidden;//允许浏览器渲染它,但是不显示出来
  }
复制代码

d.br标签清除浮动

br标签有一个clear属性,设置为all可以清除浮动

  <div id="wrap">
  <div id="inner"></div>
  <br clear="all" />
</div>
  #wrap {
    border: 1px solid;
  }
  #inner {
    float: left;
    width: 200px;
    height: 200px;
    background: pink;
  }
复制代码

参考文章:github.com/ljianshu/Bl… 浪里行舟大佬

转载于:https://juejin.im/post/5cc536775188252dcf5d515a

### CSS 清除浮动的作用及原因 #### 浮动的概念及其副作用 CSS 中的 `float` 属性用于使元素向左或向右移动,直到其碰到包含框或者另一个浮动元素为止。然而,当一个元素设置了浮动之后,它会脱离标准文档流[^1]。这种行为可能导致一些布局上的问题,比如父容器的高度塌陷和文字环绕现象。 - **父容器高度塌陷** 当子元素全部设置为浮动时,如果父容器没有任何非浮动的内容,则该父容器可能会因为无法感知到浮动子元素的实际高度而导致自身的高度变为零[^3]。 - **文字环绕问题** 如果某些文本位于浮动元素旁边,那么这些文本可能围绕着浮动元素排列,从而破坏预期的设计效果[^2]。 #### 清除浮动的目的 清除浮动的主要目的是恢复正常的文档流秩序并修复由浮动引发的各种视觉异常: 1. **解决父盒子高度塌陷问题** 父级元素可以重新识别所有子节点的真实尺寸,并据此调整自己的大小来包裹住所有的孩子节点[^5]。 2. **避免其他内容受到干扰** 下方未参与浮动的兄弟组件不会因上方漂浮物的影响而发生位置偏移或其他意外状况[^4]。 #### 常见清除浮动方法 以下是几种常用的清除浮动技术: ##### 方法一:使用空标签加样式 `.clear` 通过增加额外HTML结构,在最后面放置一个专门用来清理前面所有方向上可能出现过的任何类型的浮动状态的新区块,并赋予相应的class名称如`.clear`,再利用css定义此classes下的规则使其具备实际功能——即指定它的clear属性值设为both即可实现全面扫清作用。 ```html <div style="float:left;">...</div> <!-- 添加空白div --> <div class="clear"></div> /* 对应CSS */ .clear { clear: both; } ``` ##### 方法二:伪类选择器 `::after` 现代浏览器支持的一种更优雅的方式是借助于`:before/:after`伪元素机制自动创建虚拟DOM片段完成相同任务而不必真的往源码里塞入多余的标记符号。 ```css .parent-element::after { content: ""; display: block; clear: both; } ``` ##### 方法三:给父级设定 overflow:hidden|auto 这种方法简单粗暴有效果好但需注意兼容性以及是否会带来不必要的滚动条等问题。 ```css .parent-element { overflow: hidden; /* 或者 auto */ } ``` 以上就是关于为何要清除浮动以及具体操作手段的一些基本介绍。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值