CSS中的一些常用属性用的百分比值都是以什么为基准计算的

在css属性中,很多属性的取值可以是百分比,比如:width、height、padding、margin、font-size、line-height等,那么这些百分比值的计算是相对于谁的呢?

HTML:

<div class="parent">
     <div class="child">我是内容<div>
<div>

CSS:

.parent {
      width: 500px;
      height: 300px;
      padding:50px;
      background: #999;
      margin-left:50px;
      font-size: 12px;
      line-height:24px;
      border: 1px solid #808080;
}
.child {
     width: 50%;
     height: 20%;
     padding-left: 10%;
     margin-left:10%;
     border:2px solid black;
     font-size: 150%;
     line-height: 150%;
     background: orange;
}

此时,父div元素的content-box的宽度、高度值分别为500px、300px;padding-box的宽度、高度分别为600px、400px(左图),;子元素的font-size是18px,line-height是根据自身的font-size来的,所以line-height是18px * 150%,子div元素的各尺寸如右图所示:

 当子div元素设置float为left后,结果与上述一样,即浮动下各属性百分比的计算是和正常文档流中一样的;

 

现将子div元素设置为绝对定位

CSS(只添加绝对定位有关尺寸,其余的属性尺寸值没变):

.parent {
     position: relative;
}
.child {
     position: absolute;
     top: 20%;
     left: 20%;
}

子元素的宽度、高度、内外边距等属性值变化如下所示:

由上述例子,现总结如下:

一、font-size

当前的字体大小等于100%;

二、line-height

line-height的计算值就是当前字体的值乘以该百分比。注意line-height取值为数值或者百分比的差异,此处不细致讲解;

三、width

正常文档流中和设置浮动的情况下,相对于父元素content-box的宽度为基准计算;绝对定位时,相对于padding-box的宽度为基准计算;

四、height

height对百分比也是支持的,但是其和width还是有一个明显的区别:当父元素width属性为auto时,子元素宽度仍然可以使用百分比设置。但是对于height,只要子元素还是在正常文档流当中的,如果父元素的height属性为auto,则子元素height设置为百分比会被忽略。规范中指出:如果包含块的高度没有显式指出(即高度由内容决定),并且该元素不是绝对定位,则计算值为auto。而auto*100/100=NaN。所以,若要高度的百分比设置有效,需要如下设置:

body,html {
      height: 100%  
}

上述高度计算,都是对于正常流

五、margin、padding

无论是垂直或水平方向,均是相对于父元素的宽度,正常文档流中和设置浮动的情况下,相对于父元素content-box的宽度;绝对定位时,相对于padding-box的宽度;

六、定位元素的left/right/bottom/top百分比值

 top、bottom设置百分比定位是按padding-box的高度来计算的,left、right设置百分比定位是按padding-box的宽度来计算的。

posted @ 2020-04-20 16:02  90一代  阅读(666)  评论(0编辑  收藏  举报