Wie man eine Box mit einem Bild füllt, ohne es zu verzerren
In diesem Leitfaden können Sie eine Technik erlernen, um ein HTML-Bild vollständig in eine Box einzufügen.
Verwendung von object-fit
Wenn Sie ein Bild mit dem HTML-Element <img>
zu einer Seite hinzufügen, behält das Bild die Größe und das Seitenverhältnis der Bilddatei oder der HTML-Attribute width
oder height
bei. Manchmal möchten Sie, dass das Bild die Box, in die Sie es platziert haben, komplett ausfüllt. In diesem Fall müssen Sie zuerst entscheiden, was passiert, wenn das Bild das falsche Seitenverhältnis für den Container hat.
- Das Bild sollte die Box vollständig ausfüllen, das Seitenverhältnis beibehalten und den Überschuss auf der zu großen Seite abschneiden.
- Das Bild sollte innerhalb der Box passen, wobei der Hintergrund als Streifen auf der zu kleinen Seite sichtbar wird.
- Das Bild sollte die Box ausfüllen und sich dehnen, was bedeuten könnte, dass es im falschen Seitenverhältnis angezeigt wird.
Die Eigenschaft object-fit
macht jede dieser Herangehensweisen möglich. Im nachstehenden Beispiel können Sie sehen, wie unterschiedliche Werte von object-fit
funktionieren, wenn dasselbe Bild verwendet wird. Wählen Sie den Ansatz, der am besten zu Ihrem Design passt.
<div class="wrapper">
<div class="box box1">
<img
alt="a colorful hot air balloon against a clear sky"
src="https://mdn.github.io/shared-assets/images/examples/balloon.jpg" />
</div>
<div class="box box2">
<img
alt="a colorful hot air balloon against a clear sky"
src="https://mdn.github.io/shared-assets/images/examples/balloon.jpg" />
</div>
<div class="box box3">
<img
alt="a colorful hot air balloon against a clear sky"
src="https://mdn.github.io/shared-assets/images/examples/balloon.jpg" />
</div>
</div>
.wrapper {
height: 200px;
display: flex;
gap: 20px;
}
.box {
border: 5px solid #000;
}
.box img {
width: 100%;
height: 100%;
}
.box1 img {
object-fit: cover;
}
.box2 img {
object-fit: contain;
}
.box3 img {
object-fit: fill;
}