元素竖向的百分比设定是相对于容器的高度吗?

元素竖向的百分比设定是相对于容器的高度吗?

一般而言,子元素的百分比设定都是以父元素为依据,子元素的宽度百分比依赖父元素的宽度百分比,子元素的高度百分比依赖父元素的高度百分比。那么margin ,padding这些属性也是如此吗?
不是的,举个例子.
如下代码设置了父元素的宽和高位200*100px。
之后对子元素的margin-top设置的20%。
那么这20%是200的20%还是100的20%?
一般可能觉得是100的20%。高对高嘛。然而事实并非如戏。是200的20%。证据如下,打开浏览器看看p元素的盒子。

<div class="con">
<p> this is a test</p>
</div>

<style>
    .con {
        width:200px;
        height:100px;
        background: gray;
    }
    p {
        background : yellow;
        margin-top: 20%;
        
    }
</style>

上述代码中p的盒子如图所示.可以看出margin是40。那么显然是200*20%得来的。

image.png

如果是padding-top:20%呢?
可以看到,这个padding-top也是相对于父元素的width计算的来的。


image.png

那么padding-left呢?

image.png

哎怎么也是40呢??
这个为啥呢??

总结

对于竖直方向的margin和padding,参照父元素的宽度。
对于水平方向的margin和padding,也是参照父元素的宽度。

为什么这么设置?

不知道。

参考

你未必知道的CSS小知识:元素竖向的百分比设定是相对于容器的宽度,而不是高度 - 推酷

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,814评论 1 92
  • •前端面试题汇总 一、HTML和CSS 21 你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么? ...
    Simon_s阅读 2,228评论 0 8
  • 1.块级元素和行内元素 块级(block-level)元素;行内(内联、inline-level)元素。 块元素的...
    饥人谷_小侯阅读 2,050评论 1 4
  • 最近觉得,我学CSS学得太不细致了,margin、padding这些天天都在用的属性,我却没有真正了解它们、掌握它...
    盛夏晚清风阅读 2,018评论 6 9
  • 咱们先看手册中关于宽的描述: 语法:width:<length> | | auto默认值:auto继承性:无动...
    microkof阅读 1,850评论 2 2