TOC
前言
在某些特定的场景中,如视频播放、可视化图表占位等一些高宽需要固定的比例。如果占位区间是由固定值确定,那么我们皆大欢喜,但在目前的的应用发展中宽高自适应的方式才能满足我们的需求,那么我们该如何这种自适应的宽高比布局呢?
什么是宽高比?
宽高比也称纵横比,元素的纵横比描述了其宽度和高度之间的比例关系。两种常见的视频宽高比为4:3和16:9。要保持div的宽高比,通过为padding-top
/padding-bottom
添加一个百分比值。不同的宽高比具有不同的百分比值。或采用视窗单位vw
/vh
设置相应高宽。其中一些如下所示:
aspect ratio | padding-bottom/top value | vw/vh(width|height) |
---|---|---|
16:9 | 56.25% | 100vw | 56.25vw |
4:3 | 75% | 100vw | 75vw |
3:2 | 66.66% | 100vw | 66.66vw |
8:5 | 62.5% | 100vw | 62.5vw |
2:1 | 50% | 100vw | 50vw |
aspect-ratio
适用场景:现代浏览器
优点: 只需一个属性即可实现
该属性为CSS3新的特性,为盒子规定了首选纵横比,这个纵横比可以用于计算 auto 尺寸以及其他布局函数。使用方式如下:
aspect-ratio: 1 / 1;
aspect-ratio: 16 / 9;
aspect-ratio: 0.5;
在aspect-ratio
属性没出现之前我们主要的解决方案为接下来讲到的几种。
利用padding-top/bottom适配
在CSS中margin
与padding
的百分比值是根据容器的width来计算,利用这一性质我们可以通过设置padding-top/bottom
的百分比值实现。 采用这种方法,需要把容器的height设置为0,最终容器实际高度由padding撑出。在此基础上又可分为伪元素与内容绝对定位两种方案。这也是目前最佳的处理方式。具体实现如下:
Note: 示例均采用2:1的关系
1、伪元素
适用场景:IE8+ 、现代浏览器
优点: DOM节点少、可响应式、需精确到像素
<div class="aspect-ration"></div>
.aspect-ration { background-color: #f00; }
.aspect-ration::before {
content: "";
float: left;
padding-bottom: 50%;
}
.aspect-ration::after {
clear: both;
content: "";
display: table;
}
2、内容绝对定位
适用场景:IE8+ 、现代浏览器 优点: 可响应式、精确到像素
<div class="aspect-ration">
<div class="content"></div>
</div>
.aspect-ratio {
height: 0;
overflow: hidden;
padding-top: 50%;
background: #f00;
position: relative;
}
.content {
position: absolute; top: 0; left: 0; right: 0; bottom: 0;
/* 或者 */
/* position: absolute; top: 0; left: 0; width: 100%; height: 100%; */
}
视窗单位 vw/vh
利用视窗单位是一种相对于屏幕大小的计算方式,同理我们也也可用用rem
来达到相同的效果。具体实现与视窗单位一样。
适用场景:IE10+ 、现代浏览器
优点: DOM节点少、可响应式
<div class="aspect-ratio"></div>
1、固定值
值的计算可参考文章头部表格
/* vw */
.aspect-ratio{ width: 100vw; height: 50vw; }
/*vh */
.aspect-ratio{ width: 100vh; height: 50vh; }
2、calc()
利用
calc()
可以动态计算相应值,我们只需要知晓相应比值与高宽中一个值,该方式也可以延用到padding适配中。
/* vw */
.aspect-ratio{ width: 100vw; height: calc(100vw * 1 / 2); }
/*vh */
.aspect-ratio{ width: 100vh; height: calc(100vw * 1 / 2); }
以上两种方法四种实现方式可根据不同场景选用不同的方式。不过有部分情况下采用padding与伪元素的方式相对更佳。
结合居中
在些基础上,我们可能会涉及相关的对宽高比元素进行居中排版,相关细节可参考我上篇文章 CSS之居中布局
参考
Aspect Ratio Boxes
Maintain the aspect ratio of a div with CSS
Padding
The-padding