padding-top: 100% 的问题

<div class="image-header">
    <img src="xxx.png">
</div>

style如下:

.image-header
  position: relative
  width: 100%
  padding-top: 100%   
  height: 0
  img
    position: absolute
    top: 0
    left: 0
    width: 100%
    height: 100%

为什么img设置height:100%,但是父元素设置的height为0,却可以显示图片呢

阅读 7.2k
6 个回答

img{width:100%;height:auto;}就可以实现自适应了,

image-header加上overflow:hidden

子级脱离文档流后,子级的width/height为(设置了static以外定位的)父级width/height+padding

因为你有 padding-top: 100%
不仅会显示高度,还会和你的宽度一样,是一个长宽相等的正方形的布局。

padding-top:100% 就是让这个盒子生成一个正方形

新手上路,请多包涵

因为img设置了position:absolute,元素会加上父级的padding进行计算。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题