宽度自适应100%,宽高比为16:9,即100%:h = 16:9,计算出来矩形高度 h = 56.25%
父元素设置height:0;padding-bottom:56.25%;是为了让子元素适应父元素的高度,子元素高度 = 父元素的 padding-bottom;
注意:如果子元素基于父元素使用绝对定位,子元素的高度计算就只是基于父元素的高度0,而不考虑父元素的padding值,此时子元素的高度为 100% * 0 = 0。
父元素设置相对定位,子元素使用绝对定位,并且子元素高度设置为100%,是为了让子元素的百分比高度计算,是基于父元素的padding区域 + 父元素的height。
此时子元素高度 = 100% * (56.52% + 0)= 56.52%
子元素的宽高比例为 100%:56.52% = 16:9
代码如下
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>CSS实现宽度自适应100%,宽高16:9比例的矩形</title>
<style>
* {
margin: 0;
padding: 0;
}
.container {
width: 100%;
height: 0;
padding-bottom: 56.25%; /*让子元素的高度 = 父元素的padding-bottom*/
position: relative;
}
.box {
width: 100%;
height: 100%;
background-color: green;
position: absolute;
}
</style>
</head>
<body>
<div class="container">
<div class="box">这是一个宽度自适应100%,宽高比例为16:9的矩形</div>
</div>
</body>
</html>