CSS-清除浮动

为什么要清除浮动

由于父盒子在很多情况下,不方便给高度,但子盒子浮动后又不占又位置,因此需要清除浮动防止父元素高度塌陷
 

清除浮动的本质
  • 清除浮动的本质是清除浮动元素造成的影响
  • 如果父盒子本身有高度,则不需要清除浮动
  • 清除浮动之后,父级就会根据浮动的子盒子自动检测高度,父级有了高度,就不会影响下面的标准流了
     
清除浮动的策略
  • 闭合浮动,只会让浮动在父盒子内部影响,不影响父盒子外部的其他盒子
     

清除浮动的四种方法

1.额外标签法或隔墙法,(新增加的盒子必须是块级元素)
		.box1 {
            border: 1px solid green;
        }

        .fl {
            float: left;
            width: 100px;
            height: 100px;
            background-color: red;
        }

        
        .fr {
            float: right;
            width: 100px;
            height: 100px;
            background-color: blue;
        }
        
        .clear{
        	clear:both;
        }
		<div class="box1">
        	<div class="fl">1</div>
       	 	<div class="fr">2</div>
       		 <!-- 新增加的盒子必须要求是块级元素 -->
        	<div class="clear"></div>
    	</div>
2.父级添加overflow属性

优点:代码简洁
缺点:无法显示溢出部分

	.box2 {
            /* 清除浮动 */
            overflow: hidden;
            border: 1px solid green;
        }
	<div class="box2">
        <div class="fl">1</div>
        <div class="fr">2</div>
    </div>

此方法触发了BFC

什么是BFC

BFC(Block Formatting Context) 块级格式化环境
BFC是一个CSS中的一个隐含的属性,可以为一个元素开启BFC,开启BFC该元素会变成一个独立的布局区域

元素开启BFC的特点:
1.开启BFC的元素不会被浮动元素所覆盖
2.开启BFC的元素子元素和父元素外边距不会重叠
3.开启BFC的元素可以包含浮动的子元素

可以通过一些特殊方式来开启元素的BFC:
1.设置元素的浮动(不推荐)
2.将元素设置为行内块元素(不推荐)
3.将元素的overflow设置为一个非visible的值
常用的方式为元素设置 overflow:hidden; 以开启其BFC,使其开启包含浮动元素,防止高度塌陷

3.父级添加after伪元素
		.clearfix::after {
            content: '';
            display: block;
            height: 0;
            clear: both;
            visibility: hidden;
    }
       	<div class="box3 clearfix">
        <div class="fl">1</div>
        <div class="fr">2</div>
    </div>
4、父级添加双伪元素(clearfix这个样式可以同时解决高度塌陷和外边距重叠的问题)
	.clearfix::before,
    .clearfix::after {
            content: '';
            display: table;
        }

    .clearfix:after {
            clear: both;
        }
    <div class="box4 clearfix">
     	<div class="fl">1</div>
       	<div class="fr">2</div>
    </div>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值