aspect-ratio
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2021.
Die aspect-ratio
CSS Eigenschaft ermöglicht es Ihnen, das gewünschte Breiten-Höhen-Verhältnis eines Elementbox festzulegen. Das bedeutet, dass selbst wenn sich die Größe des übergeordneten Containers oder des Ansichtsfensters ändert, der Browser die Abmessungen des Elements anpasst, um das angegebene Breiten-Höhen-Verhältnis beizubehalten. Das angegebene Seitenverhältnis wird bei der Berechnung automatischer Größen und einiger anderer Layout-Funktionen verwendet.
Mindestens eine der Box-Größen muss automatisch sein, damit aspect-ratio
eine Wirkung hat. Wenn weder die Breite noch die Höhe eine automatische Größe ist, hat das angegebene Seitenverhältnis keinen Einfluss auf die bevorzugten Größen der Box.
Probieren Sie es aus
aspect-ratio: auto;
aspect-ratio: 1 / 1;
aspect-ratio: 16 / 9;
aspect-ratio: 0.5;
<section id="default-example">
<img
class="transition-all"
height="640"
id="example-element"
src="/shared-assets/images/examples/plumeria.jpg"
width="466" />
</section>
#example-element {
height: 100%;
width: auto;
}
Syntax
aspect-ratio: 1 / 1;
aspect-ratio: 1;
/* fallback to 'auto' for replaced elements */
aspect-ratio: auto 3/4;
aspect-ratio: 9/6 auto;
/* Global values */
aspect-ratio: inherit;
aspect-ratio: initial;
aspect-ratio: revert;
aspect-ratio: revert-layer;
aspect-ratio: unset;
Diese Eigenschaft wird als eines oder beides der Schlüsselwörter auto oder ein <ratio>
angegeben. Wenn beides angegeben ist und das Element ein ersetztes Element ist, wie zum Beispiel ein <img>
, wird das angegebene Verhältnis verwendet, bis der Inhalt geladen ist. Nach dem Laden des Inhalts wird der auto
-Wert angewendet, sodass das intrinsische Seitenverhältnis des geladenen Inhalts verwendet wird.
Wenn das Element kein ersetztes Element ist, wird das angegebene ratio
verwendet.
Werte
auto
-
Ersetzte Elemente mit einem intrinsischen Seitenverhältnis verwenden dieses Seitenverhältnis, andernfalls hat die Box kein bevorzugtes Seitenverhältnis. Größenberechnungen, die das intrinsische Seitenverhältnis betreffen, arbeiten immer mit den Abmessungen des Inhaltfeldes.
<ratio>
-
Das bevorzugte Seitenverhältnis der Box ist das angegebene Verhältnis von
Breite
/Höhe
. WennHöhe
und das vorhergehende Schrägstrich-Zeichen weggelassen werden, ist die Standardeinstellung fürHöhe
1
. Größenberechnungen, die auf das bevorzugte Seitenverhältnis basieren, arbeiten mit den durchbox-sizing
festgelegten Abmessungen der Box. auto && <ratio>
-
Wenn sowohl
auto
als auch ein<ratio>
zusammen angegeben sind, wirdauto
verwendet, wenn das Element ein ersetztes Element mit einem natürlichen Seitenverhältnis ist, wie z.B. ein<img>
Element. Andernfalls wird das angegebene Verhältnis vonBreite
/Höhe
als bevorzugtes Seitenverhältnis verwendet.
Formale Definition
Anfangswert | auto |
---|---|
Anwendbar auf | all elements except inline boxes and internal ruby or table boxes |
Vererbt | Nein |
Berechneter Wert | wie angegeben |
Animationstyp | by computed value type |
Formale Syntax
aspect-ratio =
auto ||
<ratio>
<ratio> =
<number [0,∞]> [ / <number [0,∞]> ]?
Beispiele
Untersuchen der Effekte des Seitenverhältnisses bei fester Breite
In diesem Beispiel wurde die Breite der <div>
Elemente auf 100px
gesetzt und die Höhe auf auto
. Da der Breitenwert hier festgelegt ist, beeinflusst die Eigenschaft aspect-ratio
nur die Höhe der <div>
Elemente, um das angegebene Breiten-Höhen-Verhältnis beizubehalten.
div {
width: 100px;
height: auto;
}
div:nth-child(1) {
aspect-ratio: 1/1;
}
div:nth-child(2) {
aspect-ratio: 0.5;
}
div:nth-child(3) {
aspect-ratio: 1;
}
div:nth-child(4) {
aspect-ratio: 1/0.5;
}
div:nth-child(5) {
aspect-ratio: 16/9;
}
Rückgriff auf das natürliche Seitenverhältnis
In diesem Beispiel verwenden wir zwei <img>
Elemente. Das erste Element hat sein src
Attribut nicht auf eine Bilddatei gesetzt.
<img src="" /> <img src="plumeria.jpg" />
Der folgende Code setzt 3/2
als bevorzugtes Seitenverhältnis und auto
als Rückfalloption.
img {
display: inline;
width: 200px;
border: 2px dashed red;
background-color: lime;
vertical-align: top;
aspect-ratio: 3/2 auto;
}
Beachten Sie, wie das erste Bild ohne ersetzten Inhalt das 3/2
Seitenverhältnis beibehält, während das zweite Bild nach dem Laden des Inhalts das natürliche Seitenverhältnis des Bildes verwendet.
Spezifikationen
Specification |
---|
CSS Box Sizing Module Level 4 # aspect-ratio |
Browser-Kompatibilität
BCD tables only load in the browser