CSS中出现外边距塌陷如何解决

CSS中出现外边距塌陷如何解决?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

首先我们先看出现外边距塌陷的三种情况:

CSS中出现外边距塌陷如何解决

1.当上下相邻的两个块级元素相遇,上面的元素有下边距margin-bottom,下面的元素有上边距margin-top,则它们之间的垂直距离取两个值中的较大者。

<style>
.box1{
width:150px;
height:100px;
margin-bottom:20px;
background-color:rgb(201,239,98);
}
.box2{
width:100px;
height:100px;
background-color:rebeccapurple;
margin-top:10px;
}
</style>
<divclass="box1"></div>
<divclass="box2"></div>

这时候两个盒子之间的垂直距离不是30px,而是20px。

解决方法:

尽量只给一个盒子添加margin值

2.对于两个嵌套关系的块元素,如果父元素没有上内边距及边框,父元素的上外边距会与子元素的上外边距发生合并,合并后的外边距为两者中的较大者。

<style>
.box1{
width:150px;
height:100px;
margin-top:20px;
/*border:1pxsolid#000000;*/
background-color:red;
}

.box2{
width:100px;
height:100px;
/*border:1pxsolid#000000;*/
background-color:rebeccapurple;
margin-top:10px;
}
</style>
</head>

<body>
<divclass="box1">
<divclass="box2"></div>
</div>
</body>

这时候两个盒子会发生合并,上外边距为20px。

解决办法:

①给父元素定义上边框

②给父元素定义上内边距

③给父元素添加 overflow:hidden;

④添加浮动

⑤添加绝对定位

3.如果存在一个空的块级元素,border、padding、inline content、height、min-height都不存在,那么上下边距中间将没有任何阻隔,上下外边距将会合并。

<pstyle="margin-bottom:0px;">这个段落的和下面段落的距离将为20px</p>

<divstyle="margin-top:20px;margin-bottom:20px;"></div>

<pstyle="margin-top:0px;">这个段落的和上面段落的距离将为20px</p>

可以理解成中间div宽度为0且上下边距融合,只取margin的最大值。

看完上述内容,你们掌握CSS中出现外边距塌陷如何解决的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注恰卡编程网行业资讯频道,感谢各位的阅读!

发布于 2021-03-13 15:37:26
收藏
分享
海报
0 条评论
169
上一篇:CSS中vertical-align属性的作用是什么 下一篇:使用css怎么实现一个背景虚化效果
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码