开发者社区> 问答> 正文

子元素设置了margin值,父元素也跟着动起来了?

我给子元素设置margin值,设置的应该是子元素与父元素之间的外边距,可是我写上之后,显示的是父元素与body元素的外边距,然后我给父元素加上了border-top:1px solid black,又达到了我预期的结果。

html:

<div class="header">
    <div class="nav">
    </div>
</div>

没设置border-top时
css:

.header{
    width: 100%;
    height: 80px;
    position: relative;
}
.nav{
    border: 1px solid black;
    width: 980px;
    margin: 10px auto 10px;
    overflow: hidden;----因为内部有float元素

screenshot

展开
收起
杨冬芳 2016-06-08 09:38:16 2372 0
1 条回答
写回答
取消 提交回答
  • IT从业

    经典问题:垂直外边距叠加

    原因:普通文档流盒子间,只要垂直外边距直接接触就会发生合并,合并后外边距视觉高度取两个发生合并外边距中较大者。
    发生这一现象的有三种情况:相邻兄弟块元素间、父元素及其首子元素和末子元素间(没有内边距或边框把外边距分隔开)、空块级元素自身的合并。

    题主的情况是第二种吧(图贴反了),原先合并后取的是.nav元素的外边距大小,你设置了border-top之后就把父元素的外边距和子元素的外边距隔开了,这时不会发生合并了。

    2019-07-17 19:31:11
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载