根据高度保持div的纵横比[重复]

Posted

技术标签:

【中文标题】根据高度保持div的纵横比[重复]【英文标题】:Maintain aspect ratio of a div according to height [duplicate] 【发布时间】:2014-07-10 10:43:57 【问题描述】:

我必须保持 div 相对于窗口调整高度的纵横比

我可以使用padding-bottom;padding-top; 保持纵横比(x:y) 相对于宽度(X%)。

所以类比,我尝试使用padding-left;

.wrapper
   height: Y%,
   position: relative;


.wrapper:after
   padding-left: Y(x/y)%;
   display:block;

但是padding-left 的百分比值并没有给包装器任何宽度。

如何根据高度保持该 div 的纵横比?

【问题讨论】:

简而言之,您想要一个响应式 div 块保持高度和宽度的纵横比? 是的,但与高度有关。 【参考方案1】:

由于 % padding/margin 是根据约束的宽度计算的,所以不能使用“填充技术”来根据高度来保持纵横比。

对于 CSS 解决方案,您必须使用 vh 单位:

vh : 视口高度的 1/100。

Source

浏览器支持见canIuse


1:1 纵横比示例:

DEMO

CSS

div
    width: 50vh;
    height: 50vh;

【讨论】:

不幸的是,这是相对于整个窗口的。我希望有一个相对于容器的解决方案......

以上是关于根据高度保持div的纵横比[重复]的主要内容,如果未能解决你的问题,请参考以下文章

根据宽度和高度保持纵横比

保持最小/最大高度/宽度的纵横比?

如何保持并排图像的纵横比,保持图像高度相同并在图像之间固定填充?

确保元素保持指定的纵横比

根据高度保持div纵横比

如何在FFMpeg中连接两个或多个具有相同宽度和不同高度的视频并保持相同的纵横比?