白云岛资源网 Design By www.pvray.com

前言

最近在学习很多开发过程中容易忽悠但是又很重要的知识点,很多时候用的少不代表它不重要,这里将它们写出来以记录,如果有写的不好的地方请指正。

概念

margin合并是指块级元素的上外边距与下外边距有时会合并为单个外边距,有两点需要理解。

  1. 在块级元素中,不包括浮动和绝对定位元素
  2. 只发生在和当前文档流方向的相垂直的方向上

场景

一、相邻兄弟元素margin合并

p { margin: 1em 0; }
<p>第一行</p>
<p>第二行</p>

因为第一行和第二行的元素合并在一起,所以他们的间距还是1rem,而并非上下相加。

二、父级和子元素

.div1 { margin-top: 10px; }
.div2 { margin-top: 10px; }
<div class="div1">
  <div class="div2"></div>
</div>

由于父级和子级元素的合并,所以顶部的margin为10px,而不是20px。

三、空级块元素的合并

div1 { overflow: hidden; }
div2 { margin: 1rem 0; }
<div class="div1">
  <div class="div2"></div>
</div>

这个<div>元素的margin-top和margin-bottom合并在一起,所以高度只有1rem。

解决方法

这里的解决方法我们分为三种情况来讨论,第一种就是解决兄弟元素之间的margin合并情况。
 

我们可以使用设置浮动元素来解决,例如:

p { 
  margin: 1em 0;
  float: left; 
}
<p>第一行</p>
<p>第二行</p>

第二种是父级和子元素之间的margin合并,我们使用overflow属性来解决,例如:

.div1 { 
  margin-top: 10px;
  overflow: hidden; 
}
.div2 { margin-top: 10px; }
<div class="div1">
  <div class="div2"></div>
</div>

当然,我们还可以通过设置父元素为块状格式化上下文元素、设置border、padding等方式来解决问题。

第三种情况就是空块级元素的合并,一般为空块级元素设置一个高度就能够避免margin合并的问题。

div1 { overflow: hidden; }
div2 { 
  margin: 1rem 0;
  height: 1rem; 
}
<div class="div1">
  <div class="div2"></div>
</div>

意义

CSS中的margin合并是为了更好地进行图文信息展示而设计的,为了保证图文信息排版的舒服自然。我们不仅要理解它们存在的意义,而且要合理的运用它们。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

白云岛资源网 Design By www.pvray.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
白云岛资源网 Design By www.pvray.com

P70系列延期,华为新旗舰将在下月发布

3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。

而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?

根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。