【CSS】保持元素宽高比

本文介绍了在视频或图片展示页面中保持元素宽高比的两种常见方法:CSS的aspect-ratio属性和padding-bottom技术。前者实现简单但兼容性一般,后者兼容性最佳但代码复杂。根据项目需求选择合适的方法。
摘要由CSDN通过智能技术生成

保持元素的宽高比,在视频或图片展示类页面是一个重要功能。
本文介绍其常规的实现方法。

实现效果

当浏览器视口发生变化时,元素的尺寸随之变化,且宽高比不变。
在这里插入图片描述

代码实现

我们用最简单的元素结构来演示,实现宽高比为4:3。

<div class="box"></div>
.box {
	width: 50%;
	margin: 100px auto;
	background-color: pink;
	height: // 要实现高度自适应,这里就不能固定高度了。
}

接下来我们介绍 2 种方案来实现。

aspect-ratio

在 CSS 中有一个 aspect-ratio 属性专门来做这件事情。我们只需增加一行代码即可实现上述效果。

.box {
	width: 50%;
	margin: 100px auto;
	background-color: pink;
	aspect-ratio: 4 / 3;
}

优点:实现简单。
缺点:兼容性一般。
在这里插入图片描述

如果介意 aspect-ratio 的兼容性问题,这里还有另一种办法实现。

Padding 大法

直接上完整代码:

<div class="box">
  <div class="inner-box">
     <div class="container">
       <!-- 这里放实际的内容 -->
     </div>
   </div>
</div>
.box {
	width: 50%;
	margin: 100px auto;
	background-color: pink;
}

.inner-box {
	 width: 100%;
	 padding-bottom: 75%;
	 position: relative;
}

.container {
	 position: absolute;
	 inset: 0;
}

这里 inner-boxpadding-bottom 来撑开高度,75% 是相对于其包含块(此处为box)的宽度,以此做到高度自适应。

由于inner-box 的高度为0,我们在其内部再加一个元素 container,并设置绝对定位 inset:0来撑满宽高。

这种方式虽然实现起来麻烦一点,但兼容性最好。

以上就是保持元素宽高比的两种实现方式,可以根据实际的场景选择合适的方式。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值