CSS属性之margin

0.对自身可视宽度的影响

1>改变处于标准文档流中,未设置width值的block元素的可视宽度

在标准文档流中,对于没有设置宽度的block元素,当其具备内容或者设置高度后,其自身宽度为父元素宽度的100%,这个时候给block元素设置水平方向的margin值,就会改变元素的可视宽度。可是不能改变高度,由于block元素的高度是固定或者等于其内容的高度,并不会拉伸。bootstrap

这个特色在bootstrap的布局里就有用到。布局

<div class="wrap">
  父元素padding: 0 10px;
  <div class="yellow">此block元素没有设置margin值</div>
  <div class="red">此block元素设置margin-left:-10px;margin-right:-10px; 拉伸了元素宽度</div>
</div>
* {margin:0; padding:0;}

.wrap {
  width: 400px;
  height: 400px;
  margin: 50px auto;
  padding: 0 10px;
  border: 1px solid #ccc;
}
.red {
  height: 100px;
  background-color: red;
  margin: 0 -10px;
}
.yellow {
  height: 100px;
  background-color: yellow;  
}

2>改变未设置宽度,可是设置了定位(成对设置的定位,如:top/bottom,left/right)的绝对定位元素的可视宽高

当绝对定位元素没有设置width,但设置了top/bottom,left/right值时,元素会被拉伸。好比设置left:0; right:0; 元素的宽度就是第一个相对定位的父元素的宽度的100%了,这时也能经过margin来改变元素的可视宽度。一样,对于绝对定位元素,咱们也能改变它的可视高度。flex

 

<div class="wrap">
  父元素position: relative;
  <div class="yellow">绝对定位,而且设置top:0; bottom:0; 垂直拉伸元素,经过设置margin来改变可视高度</div>
</div>
* {margin:0; padding:0;}

.wrap {
  position: relative;
  width: 400px;
  height: 400px;
  margin: 50px auto;
  border: 1px solid #ccc;
}
.yellow {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 100px;
  margin: 50px 0;
  background-color: yellow;  
}

1.百分比值的margin

跟padding同样,对于正常处于标准文档流的元素而言,当元素的margin值为百分比值时,其实际值等于父元素的宽度*百分比;spa

当元素设置绝对定位后,其实际值等于第一个相对于它定位的父元素的宽度*百分比code

<div class="wrap">
  父元素宽度400px;
  <div class="yellow">margin-top:10%; 实际的margin-top=400px*10%=40px</div>
</div>
* {margin:0; padding:0;}

.wrap {
  width: 400px;
  height: 400px;
  margin: 50px auto;
  border: 1px solid #ccc;
}
.yellow {
  width: 200px;
  height: 200px;
  margin-top: 10%;
  background-color: yellow;  
}

2.margin重叠

margin重叠一般发生在兄弟元素之间以及父子元素之间,若是你们平时没有注意的话,margin重叠可能经常会给咱们带来一些小麻烦,这里就把发生margin重叠的状况总结一下。blog

1>兄弟元素之间

当两个元素发生margin重叠时,其实际值的状况:文档

  1. 当两个margin值都为正时,实际值=两个中较大的值
  2. 当两个margin值是一正一负时,实际值=两个值相加
  3. 当两个margin值都为负时,实际值=两个中绝对值大的

那何时会发生margin重叠呢?it

对于两个相邻的兄弟元素而言,只要是处于标准文档流中的block元素,垂直方向都会发生margin重叠。io

2>父元素与第一个/最后一个子元素之间

  1. 设置border-top/bottom
  2. 设置padding-top/bottom
  3. 设置overflow:hidden/auto等属性,实现BFC

3.margin的auto值

给一个定宽的block元素设置margin: 0 auto;使元素水平居中,这应该是不少人常常使用的,不过对于auto值的具体做用,可能不多有人知道。class

简单点说,对于未设置固定width或height值的元素,若是能自动拉伸,那么当设置了固定值后,auto就能够用来分配剩余空间大小。

感受有点拗口,举个例子,有一个定宽的block元素,咱们想让他在右边显示,最经常使用的就是使用float属性,不过用margin-left: auto;同样能够实现:

<div class="wrap">
  <div class="red">margin-left: auto;</div>
</div>
* {margin:0; padding:0;}

.wrap {
  position: relative;
  width: 400px;
  height: 400px;
  margin: 50px auto;
  border: 1px solid #ccc;
}
.red {
  width: 100px;
  height: 100px;
  background-color: red;
  margin-left: auto;
}

设置margin值为auto的有效场景包括:

  1. 普通定宽block元素,水平方向设置有效;
  2. 绝对定位元素,在设置了成对left/right,top/bottom或者都设置的状况下,定宽或定高都有效;
  3. 在父元素为display: flex;的状况下,子元素margin值为auto都有效
相关文章
相关标签/搜索