css保持元素宽高比

64 阅读1分钟

给各位前端的小伙伴丢个问题,元素的高度如何跟宽度保持一定的比例,比如16:9、4:3。下面我是的解决办法,利用padding继承父元素宽度的特性实现。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<style>
    /* 父盒子 */
    .container {
        width: 50%;
        margin: 0 auto;
        background-color: red;
    }
    /* 子盒子 */
    .inner {
        width: 100%;
        padding-bottom: 75%;
        background-color: pink;
        position: relative;
    }
    /* 容器 因为子盒子没有高度需要容器来存放 */
    .item {
        position: absolute;
        width: 100%;
        height: 100%;
    }
</style>
<body>
    <div class="container">
        <div class="inner">
            <div class="item"></div>
        </div>
    </div>
</body>
</html``