margin 合并
margin合并:
父级元素的上外边距和下外边距会合并为单个外边距,这种现象称为margin合并。
margin合并的两个条件:垂直方向、块级元素
margin合并的场景:
1.相邻兄弟元素之间:垂直方向上合并为最大值。
2.父子元素之间:会造成margin-top塌陷(就是垂直方向上的margin不但会发生合并;当父元素没有设置内边距或边框时,以及触发BFC时,如果子元素的值大于父元素时,子元素会带着父元素一起偏移)。
如何解决margin塌陷:
1.将父级元素设为BFC;
2.父级元素设置border-top或padding-top值;
3.父级元素和第一个子元素之间添加内联元素进行分隔。
margin合并的计算规则:
正正取大值;正负值相加;负负取最负。
margin合并是bug吗?
margin合并不是bug。
css属性的设计是为了更好的用户体验,例如在一些新闻文章、博客经常会出现
标签等,他们都有默认的垂直方向上的margin值,有默认的margin值是为了不让标题段落挤在一起,需要让垂直方向上层次分明来得到更好的用户体验。
如果没有margin合并的话,许多垂直方向自带默认值的margin就会使垂直方向距离过大,造成不好的用户体验。有了margin合并这种机制,就不会出现这种情况了。