文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

终于搞懂了 CSS 中的宽高比是基于什么工作的了!

2024-12-02 20:48

关注

在图像和其他响应式元素的宽度和高度之间有一个一致的比例是很重要的。在CSS中,我们使用padding hack已经很多年了,但现在我们在CSS中有了原生的长宽比支持。

在这篇文章中,我们将讨论什么是宽高比,我们过去是怎么做的,新的做法是什么。当然,也会有一些用例,对它们进行适当的回退。

什么是高宽比

根据维基百科的说法:

在数学上,比率表示一个数字包含另一个数字的多少倍。例如,如果一碗水果中有八个橙子和六个柠檬,那么橙子和柠檬的比例是八比六(即8∶6,相当于比值4∶3)。

在网页设计中,高宽比的概念是用来描述图像的宽度和高度应按比例调整。

考虑下图

比率是4:3,这表明苹果和葡萄的比例是4:3。

换句话说,我们可以为宽高比为4:3的最小框是4px * 3px框。当此盒式高度按比例调整为其宽度时,我们将有一个致宽尺寸的框。

考虑下图。

盒子被按比例调整大小,其宽度和高度之间的比例是一致的。现在,让我们想象一下,这个盒子里有一张重要的图片,我们关心它的所有细节。

请注意,无论大小如何,图像细节都被保留。通过拥有一致的高宽比,我们可以获得以下好处

计算宽高比

为了测量宽高比,我们需要将宽度除以如下图所示的高度。

宽度和高度之间的比例是1.33。这意味着这个比例应该得到遵守。请考虑

注意右边的图片,宽度÷高度的值是 1.02,这不是原来的长宽比(1.33或4:3)。

你可能在想,如何得出4:3这个数值?嗯,这被称为最接近的正常长宽比,有一些工具可以帮助我们找到它。在进行UI设计时,强烈建议你确切地知道你所使用的图像的宽高比是多少。使用这个网址可以帮我们快速计算。

网址地址:http://lawlesscreation.github.io/nearest-aspect-ratio/

在 CSS 中实现宽高比

我们过去是通过在CSS中使用百分比padding 来实现宽高比的。好消息是,最近,我们在所有主要的浏览器中都得到了aspect-ratio的原生支持。在深入了解原生方式之前,我们先首先解释一下好的老方法。

当一个元素有一个垂直百分比的padding时,它将基于它的父级宽度。请看下图。

当有padding-top: 50%时,该值是根据其父元素的宽度来计

  1. Percentage padding = height / width 

算的。因为父元素的宽度是200px,所以padding-top会变成100px。

为了找出要使用的百分比值,我们需要将图像的高度除以宽度。得到的数字就是我们要使用的百分比。

假设图像宽度为260px,高度为195px。

  1. Percentage padding = height / width 

195/260的结果为 0.75(或75%)。

我们假设有一个卡片的网格,每张卡片都有一个缩略图。这些缩略图的宽度和高度应该是相等的。

由于某些原因,运营上传了一张与其他图片大小不一致的图片。注意到中间那张卡的高度与其他卡的高度不一样。

你可能会想,这还不容易解决?我们可以给图片加个object-fit: cover。问题解决了,对吗?不是这么简单滴。这个解决方案在多种视口尺寸下都不会好看。

注意到在中等尺寸下,固定高度的图片从左边和右边被裁剪得太厉害,而在手机上,它们又太宽。所有这些都是由于使用了固定高度的原因。我们可以通过不同的媒体查询手动调整高度,但这不是一个实用的解决方案。

我们需要的是,无论视口大小如何,缩略图的尺寸都要一致。为了实现这一点,我们需要使用百分比padding来实现一个宽高比。

HTML

  1. "card"
  2.   "card__thumb"
  3.     "thumb.jpg" alt="" /> 
  4.   
 
  •   "card__content"
  •     

    Muffins Recipe

     
  •     

    Servings: 3

     
  •   
  •  
  •  
  • CSS

    1. .card__thumb { 
    2.   position: relative
    3.   padding-top: 75%; 
    4.  
    5. .card__thumb img { 
    6.   position: absolute
    7.   left: 0; 
    8.   top: 0; 
    9.   width: 100%; 
    10.   height: 100%; 
    11.   object-fit: cover; 

    通过上述,我们定义了卡片缩略图包装器(.card__thumb)的高度取决于其宽度。另外,图片是绝对定位的,它有它的父元素的全部宽度和高度,有object-fit: cover,用于上传不同大小的图片的情况。请看下面的动图。

    请注意,卡片大小的变化和缩略图的长宽比没有受到影响。

    aspect-ratio 属性

    今年早些时候,Chrome、Safari TP和Firefox Nightly都支持aspect-ratioCSS 属性。最近,它在Safari 15的官方版本中得到支持。

    我们回到前面的例子,我们可以这样改写它。

    1.  
    2. .card__thumb { 
    3.   position: relative
    4.   padding-top: 75%; 
    5.  
    6.  
    7. .card__thumb { 
    8.   position: relative
    9.   aspect-ratio: 4/3; 

    请看下面的动图,了解宽高比是如何变化的。

    Demo 地址:https://codepen.io/shadeed/pen/ZEeMjZe

    有了这个,让我们探索原始纵横比可以有用的一些用例,以及如何以逐步增强的方法使用它。

    渐进增强

    我们可以通过使用CSS @supports和CSS变量来使用CSS aspect-ratio。

    1. .card { 
    2.   --aspect-ratio: 16/9; 
    3.   padding-top: calc((1 / (var(--aspect-ratio))) * 100%); 
    4.  
    5. @supports (aspect-ratio: 1) { 
    6.   .card { 
    7.     aspect-ratio: var(--aspect-ratio); 
    8.     padding-top: initial; 
    9.   } 

    Logo Images

    来看看下面的 logo

    你是否注意到它们的尺寸是一致的,而且它们是对齐的?来看看幕后的情况。

    1. // html 
    2. "brands__item"
    3.   "#"
    4.     "assets/batch-2/aanaab.png" alt="" /> 
    5.    
    6.  
    7. .brands__item a { 
    8.   padding: 1rem; 
    9.  
    10. .brands__item img { 
    11.   width: 130px; 
    12.   object-fit: contain; 
    13.   aspect-ratio: 2/1; 

    我添加了一个130px的基本宽度,以便有一个最小的尺寸,而aspect-ratio会照顾到高度。

    蓝色区域是图像的大小,object-fit: contain是重要的,避免扭曲图像。

    Responsive Circles

    你是否曾经需要创建一个应该是响应式的圆形元素?CSS aspect-ratio是这种使用情况的最佳选择。

    1. .person { 
    2.   width: 180px; 
    3.   aspect-ratio: 1; 

    如果宽高比的两个值相同,我们可以写成aspect-ratio: 1而不是aspect-ratio: 1/1。如果你使用flexbox或grid,宽度将是可选的,它可以被添加作为一个最小值。

    ~完,我是小智,宝,你学会了吗~

    作者:Ahmad Shadeed 译者:前端小智 来源:shadeed

    原文:https://ishadeed.com/article/css-aspect-ratio/

    本文转载自微信公众号「大迁世界」,可以通过以下二维码关注。转载本文请联系大迁世界公众号。

     

    来源:大迁世界内容投诉

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    软考中级精品资料免费领

    • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

      难度     813人已做
      查看
    • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

      难度     354人已做
      查看
    • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

      难度     318人已做
      查看
    • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

      难度     435人已做
      查看
    • 2024年上半年系统架构设计师考试综合知识真题

      难度     224人已做
      查看

    相关文章

    发现更多好内容

    猜你喜欢

    AI推送时光机
    位置:首页-资讯-后端开发
    咦!没有更多了?去看看其它编程学习网 内容吧
    首页课程
    资料下载
    问答资讯