CSS浮动引起的高度塌陷问题

2023-12-08 0 993

正常页面布局

<style>
*{
margin:0;
padding: 0;
}
.content{
width:400px;
border:1px solid #000;

}
.box{
width:200px;
height:200px;
background: greenyellow;

}
</style>

<body>
<div class="content">
<div class="box"></div>
</div>
<p>基苦阿斯蒂芬</p>
</body>

CSS浮动引起的高度塌陷问题

当给类名为.box的盒子加上浮动后

<style>
*{
margin:0;
padding: 0;
}
.content{
width:400px;
border:1px solid #000;

}
.box{
width:200px;
height:200px;
background: greenyellow;
float: left;

}
</style>

CSS浮动引起的高度塌陷问题

可以看到页面布局已经乱了,因为元素设置浮动后会脱离文档流

解决方案

1 利用BFC(给父元素加上overflow:hidden)

**缺点:父元素溢出的元素会隐藏,可能会影响页面显示 **

.content{
width:400px;
border:1px solid #000;
overflow: hidden;

}

2 加空div

要点:
1.加上一个空的块级元素
2.对块级元素进行清除浮动, 省事方法,不管理是左浮还是右浮,直接全清(clear:both)

<style>
*{
margin:0;
padding: 0;
}
.content{
width:400px;
border:1px solid #000;
/* overflow: hidden; */

}
.box{
width:200px;
height:200px;
background: greenyellow;
float: left;

}
.clear{
clear: both;
}
</style>

<body>
<div class="content">
<div class="box"></div>
<div class="clear"></div>
</div>
<p>基苦阿斯蒂芬</p>
</body>

3 利用伪元素

要点:
1 其实和加空div的原理是一致的,唯一要记住的就是把伪元素转为块级元素(display:block),否则会没有效果
2 还有伪元素的属性不要忘记加上(content:‘’)

<style>
*{
margin:0;
padding: 0;
}
.content{
width:400px;
border:1px solid #000;
/* overflow: hidden; */

}
.content::after{
content: \’\’;
display: block; // 必须要转换为块元素
clear: both;
}
.box{
width:200px;
height:200px;
background: greenyellow;
float: left;

}
/* .clear{
clear: both;
} */
</style>

<body>
<div class="content">
<div class="box"></div>
<!– <div class="clear"></div> –>
</div>
<p>基苦阿斯蒂芬</p>
</body>

到此这篇关于CSS浮动引起的高度塌陷问题的文章就介绍到这了,更多相关CSS浮动高度塌陷内容请搜索悠久资源网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持悠久资源网!

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

悠久资源 CSS CSS浮动引起的高度塌陷问题 https://www.u-9.cn/sheji/css/130172.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务