CSS 清除浮动

浮动

为了让多个块级元素显示在一行。
块级元素一行只显示一个,行内元素一行显示多个,这种正常的显示方式称为“标准流”。
所以浮动是脱标的。

但浮动也有几条性质

  1. 浮动在父级元素里面 不会超过内边距和边框的范围(父级元素设置了高度)
  2. 如果子盒子有一个浮动了,其余的子盒子都应浮动,否则由于浮动的盒子不占位置会影响其他盒子位置
  3. 有默认的隐式转换 块级元素转换为行内块元素

消除浮动

为了解决父级元素(由于内容高度不确定,未设置高度)由于子集浮动引起的内部高度为0的问题。

案例:想要构建如下布局
随便写的颜色 不要嫌丑:)
在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style>
	.father {
		border: 1px solid blue;
		width: 300px;
	}
	.big {
		width: 100px;
		height: 100px;
		background-color: red;
		float: left;
	}
	.small {
		width: 100px;
		height: 150px;
		background-color: purple;
		float: right;
	}
	.footer {
		width: 300px;
		height: 30px;
		background-color: #ccc;
	}
	</style>
</head>
<body>
	<div class="father">
		<div class="big"></div>
		<div class="small"></div>
	</div>
	<div class="footer"></div>
</body>
</html>

在这里插入图片描述
但给红色和紫色盒子加入float后,由于未给蓝色框盒子设置高度,高度为零。

解决方法:

  1. 额外标签法
  2. 父级添加overflow属性
  3. 使用after伪元素
  4. 使用before和after双伪元素
额外标签法

在最后一个浮动标签后添加属性为clear: both | left | right;的标签(一般写both)。

.clear {
		clear: both;
	}

<div class="big"></div>
<div class="small"></div>
<div class="clear"></div>
父级添加overflow属性

出发BFC方式

.father {
		border: 1px solid blue;
		width: 300px;
		overflow: hidden;  /*消除该标签子级浮动*/
	}
使用after伪元素

添加clearfix类给父级元素

	/*清除浮动*/
	.clearfix:after { /*正常浏览器 清除浮动*/
		content: "";
		display: block;
		height: 0;
		clear: both;
		visibility: hidden;
	}
	.clearfix {
		*zoom: 1; /*zoom 1 就是ie6清除浮动方式  * 代表ie7以下版本所识别*/
	}

<div class="father clearfix">  /*多标签类*/
使用before和after双伪元素
.clearfix:before, .clearfix:after {
		content: "";
		display: table;
	}
	.clearfix:after {
		clear: both;
	}
	.clearfix {
		*zoom: 1;
	}


<div class="father clearfix">
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值