为什么要清除浮动以及怎么清除浮动?

探讨了HTML中浮动元素对页面布局的影响,展示了不正确处理浮动可能导致的问题,并介绍了四种有效清除浮动的方法,包括使用clear样式、插入空块级元素、伪元素及overflow属性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

不清除浮动的后果

HTML结构如下:

	<div class="topDiv">
		<div class="textDiv">文本信息</div>
		<div class="floatDiv">浮动元素</div>
	</div>
	<div class="bottomDiv">
		底部元素
	</div>	

CSS样式:

.topDiv{
	width: 500px;
	border: 2px solid black;
	/* 清除浮动 */
	/* overflow: hidden; */
}
.floatDiv{
	width: 100px;
	height: 100px;
	border: 2px dotted red;
	color: red;
	margin: 4px;
	float: left;
}
.textDiv{
	color: blue;
	border: 2px solid blue;
	/*.textDiv告诉浏览器,我左边不允许有浮动元素的存在,清除左边的浮动元素*/ 
	/* clear: left;  */
}
.bottomDiv{
	width: 500px;
	height: 100px;
	margin: 5px 0;
	border: 2px solid black;
}
/* .topDiv::after{
		display: block;
		height: 0;
		content: ".";
		clear: both;
	} */

此时的效果为:
在这里插入图片描述
本来的理想效果应该是浮动元素撑开上面的容器,然而并没有,这就是浮动的影响。

清除浮动的方法

  1. 利用clear样式,指定某个元素的某边不能有浮动元素
  2. 在父元素结束标签之前插入空的块级元素设置:clear:both
  3. 利用伪元素清除浮动(::after,::before等)
  4. 利用overflow清除浮动(设定除visible以外的任何有效值都可以,一般设置为hidden)
原理为触发了BFC(块格式化上下文,即块级元素的布局规范)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值