在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
浮动元素使其父元素高度塌陷我们经常会遇到一种情况,给一个元素设置浮动之后 从以上两张图中可以看出添加浮动元素后,li元素按照规则横向排列,但是父元素却消失不见了。
为父元素添加一个5px的边框,在li元素添加浮动后,边框并没有被内容撑开。 在第一个示例中仿佛父元素消失了,但在第二个示例中发现其实父元素并没有消失,只是高度被计算为0。这就要回到浮动元素的特性来说明此问题“当元素设置浮动后,会自动脱离文档流”,翻译成白话就是说,元素浮动后,就不在整个文档流的管辖范围,那么它之前存在在父元素内的高度就随着浮动不复存在了,而此时父元素会默认自己里面没有任何内容(前提是未给父元素设置固定高度,如果父元素本身有固定高度,就不会出现这种情况) 解决方法: 1、给父元素也添加 overflow:hidden;
::after 伪类 利用伪类来清楚浮动,其效果跟创建一个空的div并设置其为clear:both;是一样的,只不过这里用伪类代替了空的div元素 <div class="box"> <div class="son">我是浮动的子元素</div> </div> .box { width:400px; background:#F00; } .son { float:left; } .son::after { content:""; clear:both;/*清除浮动*/ display:block;/*确保该元素是一个块级元素*/ } 到此这篇关于详解关于浮动元素float使其父元素高度塌陷的原因及解决方法的文章就介绍到这了,更多相关浮动float父元素高度塌陷内容请搜索极客世界以前的文章或继续浏览下面的相关文章,希望大家以后多多支持极客世界! |
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论