开发者社区> 问答> 正文

和父元素相同大小的子元素,设置了四边的Margin的子元素却向右侧平移了,请问是为什么啊啊啊啊……

代码是这样的:

CSS:

.test1 {
    background-color:green;
    width:500px; height:400px;
    /*border:10px solid yellow;*/
    /*position: absolute;*/
    margin:30px 0 0 30px;
}
.test2 {
    background-color:red;
    width:100%; height:100%;
    margin:30px;
}
HTML:

<div class="test1">
    <div class="test2"></div>
</div>

如上代码,在 Firefox 和 Chrome 中,子元素的margin-left都会在父容器里,子元素向右侧水平偏移,但是margin-top会从父容器溢出(也就是说,test1和test2有色彩的部分是等高的)。
按照我的理解,这样的CSS应该会让子元素向右下角偏移
看我注释掉的两条,取消任意一条的注释都能够让子元素的 margin-top 出现在父元素中
求教为什么会出现这样的情况?
究竟这两个CSS属性共同改变test1和test2的什么属性?

展开
收起
a123456678 2016-03-24 15:27:09 2202 0
1 条回答
写回答
取消 提交回答
  • 1.垂直边界重叠
    2.这两个属性任意一个使得父元素拥有块级格式化范围,避免了垂直边界重叠的问题,具有类似功能的属性还有overflow:hidden;

    2019-07-17 19:12:50
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

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