CSS 纵横比属性 --- aspect-ratio

什么是 aspect-ratio?

需求:对于一个响应式的网站,在缩放的时候,需要保持图片和视频的纵横比

传统的 CSS 只能通过 宽高自己计算纵横比,或者 保持原始纵横比.
现在可以使用 aspect-ratio 属性来设置固定的纵横比.

aspect-ratio

CSS aspect-ratio 属性接收以 "/" 分隔的两个数字作为属性值,分别代表宽度和高度的比例,例如 16 / 9 表示 16:9 的纵横比, 5 / 4 表示 5:4 的纵横比:

aspect-ratio: 16 / 9;  // 纵横比为 16:9
aspect-ratio: 5 / 4;  // 纵横比为 5:4

"/" 和后面的高度比可以省略,默认为 1

aspect-ratio: 4;  // 纵横比为 4:1

aspect-ratio 属性值也可以设置为 auto,在缩放的时候,保持一定的纵横比:

	aspect-ratio: auto;  // 保持原有的纵横比

任何一个具有宽高的元素都可以使用它:

div .box {
	aspect-ratio: 5 / 4;
}

示例:

准备一个盒子,盒子里面放入图片。无论容器的宽高怎么变化,图片都能保持 1:1 的纵横比

.box {
	width:500px;
	height:500px;
	border:1px solid red;
	resize:both; // 图片容器设置随意缩放
	overflow:auto;
}

.box img {
	max-width:100%;
	max-height:100%;
	aspect-ratio:1 / 1;   // 设置图片的纵横比为 1:1,最大高度和宽度都是容器的 100%,图片不会超出容器
}

兼容性:

使用 CSS - aspect-radio 属性,兼容性可以参考该图:

兼容性

  • 7
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值