清除浮动

1:为什么用清除浮动:很多情况下父级不方便给高度,子盒子浮动后脱离普通流,父级的高变为0,影响下面的布局。
2:方法:

1:直接给父级设置高度

<body>
	<div class="a">
	<div class="b"></div>
	<div class="c"></div>
	</div>
</body>

<style>
.a{
				
				border: 2px solid red;
				height:100px;
			}
			
			.b{
				float: left;
				background-color: green;
				width: 100px;
				height: 100px;
				border: 1px solid black;
			}
			.c{
				float: left;
				background-color: red;
				width: 100px;
				height: 100px;
				border: 1px solid yellow;
			}
<style>

2:在标签后加一个空标签,用clear属性

<body>
	<div class="a">
	<div class="b"></div>
	<div class="c"></div>
	<div class="d"></div>
	</div>
</body>

<style>
.a{
				
				border: 2px solid red;
			}
			
			.b{
				float: left;
				background-color: green;
				width: 100px;
				height: 100px;
				border: 1px solid black;
			}
			.c{
				float: left;
				background-color: red;
				width: 100px;
				height: 100px;
				border: 1px solid yellow;
			}
			.d{
			clear:both;
			}
<style>

3:在父标签上使用,:after属性

<body>
	<div class="a">
	<div class="b"></div>
	<div class="c"></div>
	</div>
	</body>

<style>
.a:after{
				display: block; //转换为块元素
				clear:both;		//清除浮动
				content: "";	//插入生成的内容
				visibility: hidden;		//隐藏
				height: 0;
			}
			.a{
				border:2px  solid red;
				zoom:1;  //为了防止低版本的IE浏览器不支持after选择器或者某些属性,在最后加上zoom:1来清除浮动。
				}
			.b{
				float: left;
				background-color: green;
				width: 100px;
				height: 100px;
				border: 1px solid black;
			}
			.c{
				float: left;
				background-color: red;
				width: 100px;
				height: 100px;
				border: 1px solid yellow;
			}
<style>

4:在父级上使用overflow: hidden;不可以position一起使用

<body>
	<div class="a">
	<div class="b"></div>
	<div class="c"></div>
	<div class="d"></div>
	</div>
</body>

<style>
.a{
				overflow:hidden;
				border: 2px solid red;
			}
			
			.b{
				float: left;
				background-color: green;
				width: 100px;
				height: 100px;
				border: 1px solid black;
			}
			.c{
				float: left;
				background-color: red;
				width: 100px;
				height: 100px;
				border: 1px solid yellow;
			}
<style>

5:使用双伪元素:

clearfix是父类
.clearfix::before,
        .clearfix:after {
            content: "";
            display: table;
        }
        
        .clearfix:after {
            clear: both;
        }
        
        .clearfix {
            *zoom: 1;
        }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值