【CSS】css 怎样实现固定宽高比

泉缘泉  论坛元老 | 2024-9-24 15:48:45 | 来自手机 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 1000|帖子 1000|积分 3010

本日和同事讨论这个题目,一时间还想不到了,于是学习了下,就顺便当个记录吧
  要在CSS中实现固定宽高比,有两种主要的方法可以选择。一种是利用新的aspect-ratio属性,另一种是利用padding技巧。随着当代浏览器对aspect-ratio属性的广泛支持,直接利用该属性已成为实现固定宽高比的首选方法。
利用 aspect-ratio 属性

aspect-ratio属性允许你界说元素盒子的宽高比,纵然父容器或视口巨细发生变化,浏览器也会调整元素的尺寸以保持指定的宽高比。至少必要一个盒子的尺寸是主动的,才能让aspect-ratio生效。如果宽度和高度都不是主动尺寸,那么提供的宽高比就不会影响盒子的首选尺寸。
以下是一个利用aspect-ratio属性的示例,它创建了一个具有16:9宽高比的元素:
  1. .aspect-ratio-16-9 {
  2.   aspect-ratio: 16 / 9;
  3.   width: 100%; /* 或者任何你想要的宽度 */
  4.   background-color: lightblue;
  5. }
复制代码
  1. <div class="aspect-ratio-16-9"></div>
复制代码
利用 padding-top 百分比技巧

对于不支持aspect-ratio属性的旧浏览器,你还可以利用padding技巧来维持元素的宽高比。这种方法基于元素的宽度百分比和其顶部填充百分比之间的关系。

以下是一个利用padding-top技巧的示例,它创建了一个宽高比为1:1的元素:
  1. .aspect-ratio-1-1 {
  2.   position: relative;
  3.   width: 100%; /* 或者任何你想要的宽度 */
  4.   padding-top: 100%; /* 高度等于宽度 */
  5.   background-color: lightblue;
  6. }
复制代码
  1. <div class="aspect-ratio-1-1"></div>
复制代码
这种方法的一个缺点是它依赖于元素的宽度,因此如果元素的宽度改变,宽高比也会改变。但是,对于大多数响应式计划来说,这种方法仍旧非常有用。
好比你想要创建一个宽高比为16:9的div,你可以通过设置padding-top的百分比值来实现。这个百分比值是基于div的宽度计算的,因此要得到16:9的宽高比,你必要将padding-top设置为9 / 16 * 100%,即56.25%。
  1. <!DOCTYPE html>
  2. <html lang="en">
  3.   <head>
  4.     <meta charset="UTF-8" />
  5.     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  6.     <title>Document</title>
  7.     <style>
  8.       .container {
  9.         position: relative;
  10.         width: 100%;
  11.         padding-top: 56.25%;
  12.         /* aspect-ratio: 16 / 9; */
  13.         background-color: red;
  14.       }
  15.       .content {
  16.         position: absolute;
  17.         top: 0;
  18.         left: 0;
  19.         bottom: 0;
  20.         right: 0;
  21.         background-color: red;
  22.         text-align: center;
  23.         line-height: 200px; /* Adjust based on your needs */
  24.         font-size: 24px;
  25.         color: black;
  26.       }
  27.     </style>
  28.   </head>
  29.   <body>
  30.     <div class="container">
  31.       <div class="content">Content Here</div>
  32.     </div>
  33.   </body>
  34. </html>
复制代码
总结

总结起来,利用aspect-ratio属性是实现固定宽高比的当代方法,因为它直接控制元素的宽高比,不受元素宽度的影响。而padding-top技巧则是一种兼容性更好的办理方案,适用于那些不支持aspect-ratio属性的旧浏览器。
参考

aspect-ratio - CSS:层叠样式表 | MDN

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

泉缘泉

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表