固定宽度,高度设置为0或者不写, padding-bottom的值为 50%样式
如下:

  * {
        margin: 0;
        padding: 0;
      }

      html,
      body {
        width: 100%;
        height: 100%;
      }

      .outer {
        width: 400px;
        height: 100%;
        background: blue;
        margin: 0 auto;
        display: flex;
        align-items: center;//垂直居中
      }

      .inner {
        position: relative;
        width: 100%;
        /* height: 0; *///可写可不写
        padding-bottom: 50%;
        background: red;
      }

      .box {
        position: absolute;
        width: 100%;
        height: 100%;
        display: flex;
        justify-content: center;//水平居中
        align-items: center;//垂直居中
      }
<div class="outer">
      <div class="inner">
        <div class="box">hello</div>
      </div>
    </div>
Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐