您现在的位置是:群英 > 开发技术 > web开发
CSS浮动导致父元素坍塌是什么原因,如何处理?
Admin发表于 2022-11-01 15:57:071103 次浏览

    今天给大家分享的是关于CSS浮动导致父元素坍塌的原因及解决方法,这个问题很多新手在刚接触CSS浮动时都会遇到,对此本文就给大家来解决CSS浮动及CSS浮动父元素坍塌的解决方法,对大家学习和理解CSS浮动会有一定的帮助。

    一、文档流与浮动

    1、’什么是文档流?

    在html中,文档流也可以叫做标准流或普通流。元素的显示方式是自上而下,从左到右,其中,块级元素默认占据一行,行内或行内块级元素只占据内容部分或自身的所占据的部分,并不会像块级元素一样霸道的占据一行,其实这也跟自然现象中的瀑布自上而下流动是一个道理^_^。

    2、不安分的浮动

    在上面我们已经初步了解了文档流,但是元素在网页中的显示仅仅依靠文档流是不够的,就比如说天猫商城的商标导航部分,无序列表ul的每个列表项li是块级元素(display:list-item),按照文档流来说,块级元素是占据一行的,所以每个li会自上而下一行行显示,但实际上每个li却只占据了自身的部分,请看下图:

    那么为什么这些li元素不按照文档流的方式显示,原因就是他们已经脱离了文档流。想让一个元素脱离文档流,方法有两种:第一种是浮动(float);第二种就是定位(position)。

    如果说,文档流是别人家做什么事都听父母的话,是个很乖很懂事的孩子,嘿嘿,那么浮动就是自家做什么事都不听话,不安分的孩子。就像我们小时候,父母经常对我们说你看看别人家孩子多么多么听话,你再看看你,怎么怎么样…

    二、浮动是把双刃剑

    既然浮动已经让元素脱离了文档流,那么我们就可以让元素的显示更为灵活,比如简易导航栏的制作:

body{
margin:0;
background-color:#333;
}
ul{
list-style:none;
width:500px;
margin:100px auto 0;
padding:0;
}
.clearfix:after{
content:"";
display:block;
clear:both;
}
ul li{
float:left;
width:100px;
height:30px;
background-color:#fff;
}
ul li a{
display:block;
height:100%;
line-height:30px;
color:#000;
text-decoration:none;
text-align:center;
}



    • 导航1



    • 导航2



    • 导航3



    • 导航4



    • 导航5


    又比如早之前的圣杯布局


body{
margin:0;
}
.wrap{
padding:0 300px;
}
.clearfix:after{
content:"";
display:block;
clear:both;
}
.middle,.left,.right{
float:left;
position:relative;
height:100px;
}
.middle{
width:100%;
background-color:#333;
}
.left{
left:-300px;
width:300px;
margin-left:-100%;
background-color:#ccc;
}
.right{
right:-300px;
width:300px;
margin-left:-300px;
background-color:#f00;
}  

 

    同时,浮动也会带来其他的影响,比如,浮动的元素会覆盖后面处于文档流中的元素

body{
margin:0;
}
.box-1{
float:left;
width:200px;
height:200px;
background-color:#333;
}
.box-2{
width:200px;
height:300px;
background-color:#ccc;
}

 


 

    为了解决上面这种问题,我们只要给BOX-2清除浮动就行了

.box-2{
clear:both;
width:200px;
height:300px;
background-color:#ccc;
}

    此外,浮动元素会导致父元素高度坍塌,如果一个没有高度的块级元素的子元素浮动的话,则这个块级父元素的高度为0,请看如下代码:

body{
margin:0;
}
.box-1{
width:300px;
background-color:#333;
}
.box-2{
float:left;
width:200px;
height:300px;
background-color:#ccc;
}


 

    大家应该知道,对于一个元素来说,不给他固定高度的时候他的高度是由内容撑开的,也就是说,如果这个元素里面没有任何内容,他的高度就是0,当这个元素有内容的时候,他就有了高度(也就是内容的高度),请看下图:

    而在上面中父元素BOX-1虽然有了子元素BOX-2,但是他的高度却为0,这到底是怎么回事呢?就是因为BOX-2浮起来了,子元素BOX-2和父元素BOX-1不在同一高度,从而BOX-1无法包裹住BOX-2,请看下图:

.box-1{
width:100px;
background-color:#f00;
}

    我是内容

    上图就是浮动带来的父元素高度坍塌问题

    三、如何解决浮动带来的父元素高度坍塌问题

    1、子级方法

在子元素的最后添加一个高度为0的子元素,并且让他清除浮动,请看一下代码:

效果图如下,红色盒子是父元素,黄色盒子是子元素BOX-2


2、父级方法

给父元素设置display:inline-block;

代码如下:

body{
margin:0;
}
.box-1{
display:inline-block;
width:300px;
background-color:#f00;
}
.box-2{
float:left;
width:200px;
height:150px;
background-color:#ff0;
}


 

给父元素设置overflow:hidden;

代码如下:

body{
margin:0;
}
.box-1{
overflow:hidden;
width:300px;
background-color:#f00;
}
.box-2{
float:left;
width:200px;
height:150px;
background-color:#ff0;
}

    上面这两种方法其实是根据BFC(块级格式化上下文),因为BFC会让父元素包含浮动的子元素,从而解决父元素高度坍塌问题,所以只要能触发BFC就行。

    给父元素固定的高度,这个没什么好说的,就不赘述了,因为在实际开发中高度一般都由内容撑开。利用伪元素:after,并且清除浮动

    以上就是关于CSS浮动导致父元素坍塌的原因及解决方法的介绍,有需要的朋友可以参考上述的方法,希望大家阅读完这篇文章能有所收获。最后,想要了解更多大家可以继续关注其他相关文章。

本文转载自网络

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

标签: css浮动
相关信息推荐
2022-07-30 17:32:07 
摘要:react新旧生命周期的区别:1、新生命周期中去掉了三个will钩子,分别为componentWillMount、componentWillReceiveProps、componentWillUpdate;2、新生命周期中新增了两个钩子,分别为getDerivedStateFromProps(从props中得到衍生的state)和getSnapshotBeforeUpdate。
2022-05-26 17:28:29 
摘要:方法1在返回的json中设置lay_checked为true,页面上的checkbox就是选中状态了。data":[ {"name":"北京市","areatype":"省/直辖市","
2021-11-03 17:49:19 
摘要:这篇文章给大家分享的是用PHP怎样实现签名验证的功能,下文将介绍PHP签名验证的实现思路、方法及代码,文中示例代码介绍的非常详细,感兴趣的朋友接下来一起跟随小编看看吧。
云活动
推荐内容
热门关键词
热门信息
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部