Heim > Web-Frontend > CSS-Tutorial > Hauptteil

Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?

青灯夜游
Freigeben: 2021-06-25 10:40:49
nach vorne
9332 Leute haben es durchsucht

Es ist sehr wichtig, ein konsistentes Verhältnis zwischen der Breite und Höhe von Bildern und responsiven Elementen zu haben. Der folgende Artikel führt Sie zum Verständnis des Seitenverhältnisses und des Seitenverhältnisattributs und stellt die Methode zur Implementierung des Seitenverhältnisses im Detail vor CSS anhand von Beispielen.

Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?

Was ist ein Seitenverhältnis?

Laut Wikipedia:

In der Mathematik gibt ein Verhältnis an, wie oft eine Zahl eine andere Zahl enthält. Befinden sich beispielsweise acht Orangen und sechs Zitronen in einer Obstschale, dann beträgt das Verhältnis von Orangen zu Zitronen acht zu sechs (also 8:6, entspricht einem Verhältnis von 4:3).

Im Webdesign wird das Konzept des Seitenverhältnisses verwendet, um zu beschreiben, wie Breite und Höhe eines Bildes proportional angepasst werden sollen.

Betrachten Sie das Bild unten

Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?

Das Verhältnis beträgt 4:3, was zeigt, dass das Verhältnis von Äpfeln zu Trauben 4:3 beträgt. 4:3

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

考虑下图。

Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?

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

Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?

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

  • 整个网站的图像将在不同的视口大小上保持一致。
  • 我们也可以有响应式的视频元素。
  • 它有助于设计师创建一个图像大小的清晰指南,这样开发者就可以在开发过程中处理它们。

计算宽高比

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

Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?

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

Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?

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

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

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

在 CSS 中实现宽高比

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

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

Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?

当标题有padding-top: 50%时,该值是根据其父元素的宽度来计算的。因为父元素的宽度是200px,所以padding-top会变成100px

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

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

Percentage padding = height / width
Nach dem Login kopieren

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

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

Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?

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

你可能会想,这还不容易解决?我们可以给图片加个object-fit: cover

Mit anderen Worten, die kleinste Box, die wir für ein Seitenverhältnis von 4:3 bekommen können, ist eine 4px * 3px-Box. Wenn die Höhe dieser Box proportional zu ihrer Breite skaliert wird, erhalten wir eine Box mit breiten Abmessungen.

Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?Betrachten Sie das Bild unten.

🎜Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?🎜🎜Box Die Größe wird proportional geändert, sodass das Verhältnis zwischen Breite und Höhe konsistent ist. Stellen wir uns nun vor, dass diese Box ein wichtiges Bild enthält und wir uns um alle Details kümmern. 🎜🎜Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?🎜🎜Bitte Beachten Sie, dass Bilddetails unabhängig von der Größe erhalten bleiben. Durch ein konsistentes Seitenverhältnis erzielen wir die folgenden Vorteile: 🎜
  • Bilder auf der gesamten Website bleiben über verschiedene Ansichtsfenstergrößen hinweg konsistent.
  • Wir können auch reaktionsfähige Videoelemente haben.
  • Es hilft Designern, eine klare Richtlinie für Bildgrößen zu erstellen, damit Entwickler während der Entwicklung damit arbeiten können.
🎜🎜Berechnung des Seitenverhältnisses🎜🎜🎜Um das Seitenverhältnis zu messen, müssen wir die Breite durch die Höhe teilen, wie im Bild unten gezeigt. 🎜🎜Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?🎜🎜Breite Das Verhältnis zwischen Höhe und Höhe beträgt 1,33. Dies bedeutet, dass dieses Verhältnis eingehalten werden sollte. Bitte beachten Sie 🎜🎜Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?🎜 🎜Beachten Sie, dass im Bild rechts der Wert von Breite ÷ Höhe 🎜1,02🎜 beträgt, was nicht dem ursprünglichen Seitenverhältnis (1,33 oder 4:3) entspricht. 🎜🎜Sie fragen sich vielleicht, wie Sie den Wert von 4:3 erhalten? Nun, das nennt man das nächste normale Seitenverhältnis, und es gibt einige Tools, die uns dabei helfen können, es zu finden. Beim UI-Design wird dringend empfohlen, dass Sie genau wissen, welches Seitenverhältnis die von Ihnen verwendeten Bilder haben. Die Verwendung dieser URL kann uns bei der schnellen Berechnung helfen. 🎜
🎜Website-Adresse: http://lawlesscreation.github.io/nearest-aspect-ratio/🎜
🎜🎜Seitenverhältnis in CSS erreichen🎜🎜🎜Früher haben wir beim CSS padding Prozentsätze verwendet um das Seitenverhältnis zu erreichen. Die gute Nachricht ist, dass wir seit kurzem native Unterstützung für aspect-ratio in allen gängigen Browsern erhalten. Bevor wir uns mit der nativen Methode befassen, erklären wir zunächst die gute alte Methode. 🎜🎜Wenn ein Element einen vertikalen prozentualen padding hat, basiert dieser auf der Breite seines übergeordneten Elements. Bitte sehen Sie sich das Bild unten an. 🎜🎜Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?🎜🎜Verdammt Wenn ein Header padding-top: 50 % hat, wird der Wert basierend auf der Breite seines übergeordneten Elements berechnet. Da die Breite des übergeordneten Elements 200px beträgt, wird der padding-top zu 100px. 🎜🎜Um herauszufinden, welcher Prozentwert verwendet werden soll, müssen wir die Höhe des Bildes durch seine Breite dividieren. Die resultierende Zahl ist der Prozentsatz, den wir verwenden möchten. 🎜🎜Gehen Sie davon aus, dass die Bildbreite 260px und die Höhe 195px beträgt. 🎜
<article class="card">
  <div class="card__thumb">
    <img src="thumb.jpg" alt="" />
  </div>
  <div class="card__content">
    <h3>Muffins Recipe</h3>
    <p>Servings: 3</p>
  </div>
</article>
Nach dem Login kopieren
Nach dem Login kopieren
🎜195/260 ergibt 0,75 (oder 75 %). 🎜🎜 Nehmen wir an, wir haben ein Kartenraster und jede Karte hat ein Miniaturbild. Die Breite und Höhe dieser Miniaturansichten sollten gleich sein. 🎜🎜Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?🎜🎜Fällig Aus irgendeinem Grund hat der Betreiber ein Bild hochgeladen, dessen Größe nicht mit anderen Bildern übereinstimmt. Beachten Sie, dass die mittlere Karte nicht die gleiche Höhe wie die anderen Karten hat. 🎜🎜Sie denken vielleicht, das ist nicht einfach zu lösen? Wir können dem Bild ein object-fit: cover hinzufügen. Problem gelöst, oder? So einfach ist das nicht. Diese Lösung wird bei mehreren Ansichtsfenstergrößen nicht gut aussehen. 🎜🎜🎜🎜

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

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

HTML

<article class="card">
  <div class="card__thumb">
    <img src="thumb.jpg" alt="" />
  </div>
  <div class="card__content">
    <h3>Muffins Recipe</h3>
    <p>Servings: 3</p>
  </div>
</article>
Nach dem Login kopieren
Nach dem Login kopieren

CSS

.card__thumb {
  position: relative;
  padding-top: 75%;
}

.card__thumb img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
Nach dem Login kopieren

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

Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?

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

aspect-ratio 属性

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

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

/* 上面的方式 */
.card__thumb {
  position: relative;
  padding-top: 75%;
}

/* 使用 aspect-ratio 属性 */
.card__thumb {
  position: relative;
  aspect-ratio: 4/3;
}
Nach dem Login kopieren

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

Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?

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

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

渐进增强

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

.card {
  --aspect-ratio: 16/9;
  padding-top: calc((1 / (var(--aspect-ratio))) * 100%);
}

@supports (aspect-ratio: 1) {
  .card {
    aspect-ratio: var(--aspect-ratio);
    padding-top: initial;
  }
}
Nach dem Login kopieren

Logo Images

来看看下面的 logo

1Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?

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

// html
<li class="brands__item">
  <a href="#">
    <img src="assets/batch-2/aanaab.png" alt="" />
  </a>
</li>
Nach dem Login kopieren
.brands__item a {
  padding: 1rem;
}

.brands__item img {
  width: 130px;
  object-fit: contain;
  aspect-ratio: 2/1;
}
Nach dem Login kopieren

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

1Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?

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

Responsive Circles

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

1Was ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?

.person {
  width: 180px;
  aspect-ratio: 1;
}
Nach dem Login kopieren

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

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

作者:Ahmad Shadeed

更多编程相关知识,请访问:编程视频!!

Das obige ist der detaillierte Inhalt vonWas ist ein Seitenverhältnis? Wie implementiert man das Seitenverhältnis in CSS?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
css
Quelle:segmentfault.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage