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;
        }
		<div class="box1">
        	<div class="fl">1div>
       	 	<div class="fr">2div>
       		 
        	<div class="clear">div>
    	div>

2.父级添加overflow属性

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

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

4、父级添加双伪元素(clearfix这个样式可以同时解决高度塌陷和外边距重叠的问题)

	.clearfix::before,
    .clearfix::after {
     
            content: '';
            display: table;
        }

    .clearfix:after {
     
            clear: both;
        }
    <div class="box4 clearfix">
     	<div class="fl">1div>
       	<div class="fr">2div>
    div>

你可能感兴趣的:(CSS,css3,html,css)