Erweiterte Styling-Effekte
Dieser Artikel dient als eine Sammlung von Tricks und bietet eine Einführung in einige interessante erweiterte Styling-Funktionen wie Boxschatten, Mischmodi und Filter.
Voraussetzungen: | Grundlagen in HTML (siehe Einführung in HTML) und eine Vorstellung davon, wie CSS funktioniert (siehe CSS Erste Schritte.) |
---|---|
Ziel: | Sich einen Überblick darüber verschaffen, wie man einige der verfügbaren fortgeschrittenen Styling-Effekte in modernen Browsern nutzt. |
Box-Schatten
box-shadow
ermöglicht es Ihnen, einem Elementkasten einen oder mehrere Schatten hinzuzufügen. Wie Textschatten werden Boxschatten in Browsern recht gut unterstützt, einschließlich IE9+ und Edge. Benutzer älterer IE-Versionen müssen möglicherweise ohne Schatten auskommen, daher testen Sie Ihre Designs, um sicherzustellen, dass Ihr Inhalt auch ohne sie lesbar ist.
Ein einfacher Boxschatten
Lassen Sie uns mit einem einfachen Beispiel beginnen, um den Einstieg zu erleichtern. Zuerst etwas HTML:
<article class="simple">
<p>
<strong>Warning</strong>: The thermostat on the cosmic transcender has
reached a critical level.
</p>
</article>
Jetzt das CSS:
p {
margin: 0;
}
article {
max-width: 500px;
padding: 10px;
background-color: red;
background-image: linear-gradient(
to bottom,
rgb(0 0 0 / 0%),
rgb(0 0 0 / 25%)
);
}
.simple {
box-shadow: 5px 5px 5px rgb(0 0 0 / 70%);
}
Dies gibt uns das folgende Ergebnis:
Sie werden sehen, dass wir vier Elemente im Wert der box-shadow
-Eigenschaft haben:
- Der erste Längenwert ist der horizontale Versatz — der Abstand, um den der Schatten vom ursprünglichen Kasten nach rechts (oder nach links, wenn der Wert negativ ist) verschoben wird.
- Der zweite Längenwert ist der vertikale Versatz — der Abstand, um den der Schatten vom ursprünglichen Kasten nach unten (oder nach oben, wenn der Wert negativ ist) verschoben wird.
- Der dritte Längenwert ist der Unschärferadius — die Menge an Unschärfe, die auf den Schatten angewendet wird.
- Der Farbwert ist die Grundfarbe des Schattens.
Sie können beliebige Längen- und Farbeinheiten verwenden, die sinnvoll sind, um diese Werte zu definieren.
Mehrere Boxschatten
Sie können auch mehrere Boxschatten in einer einzigen box-shadow
-Deklaration angeben, indem Sie sie mit Kommas trennen:
p {
margin: 0;
}
article {
max-width: 500px;
padding: 10px;
background-color: red;
background-image: linear-gradient(
to bottom,
rgb(0 0 0 / 0%),
rgb(0 0 0 / 25%)
);
}
.multiple {
box-shadow: 1px 1px 1px black,
2px 2px 1px black,
3px 3px 1px red,
4px 4px 1px red,
5px 5px 1px black,
6px 6px 1px black;
}
Jetzt erhalten wir dieses Ergebnis:
Wir haben hier etwas Spaßiges gemacht, indem wir einen erhöhten Kasten mit mehreren farbigen Schichten erstellt haben, aber Sie könnten es auf jede gewünschte Weise verwenden, zum Beispiel um einen realistischeren Look mit Schatten basierend auf mehreren Lichtquellen zu schaffen.
Weitere Box-Schatten-Funktionen
Anders als text-shadow
hat box-shadow
ein inset
-Schlüsselwort verfügbar — wenn Sie dies am Anfang einer Schattendeklaration platzieren, wird daraus ein innerer Schatten statt eines äußeren Schattens. Lassen Sie uns einen Blick darauf werfen, was wir damit meinen.
Zuerst verwenden wir für dieses Beispiel etwas anderes HTML:
<button>Press me!</button>
button {
width: 150px;
font-size: 1.1rem;
line-height: 2;
border-radius: 10px;
border: none;
background-image: linear-gradient(to bottom right, #777, #ddd);
box-shadow:
1px 1px 1px black,
inset 2px 3px 5px rgb(0 0 0 / 30%),
inset -2px -3px 5px rgb(255 255 255 / 50%);
}
button:focus,
button:hover {
background-image: linear-gradient(to bottom right, #888, #eee);
}
button:active {
box-shadow:
inset 2px 2px 1px black,
inset 2px 3px 5px rgb(0 0 0 / 30%),
inset -2px -3px 5px rgb(255 255 255 / 50%);
}
Dies gibt uns das folgende Ergebnis:
Hier haben wir eine Button-Styling eingerichtet, zusammen mit Fokus-/Hover-/Aktivzuständen. Der Button hat standardmäßig einen einfachen schwarzen Boxschatten, plus ein paar innere Schatten, einen hellen und einen dunklen, an gegenüberliegenden Ecken des Buttons, um ihm einen schönen Schattierungseffekt zu verleihen.
Wenn der Button gedrückt wird, ersetzt der aktive Zustand den ersten Boxschatten durch einen sehr dunklen inneren Schatten, was den Anschein erweckt, dass der Button eingedrückt wird.
Hinweis: Es gibt einen weiteren Punkt, der im box-shadow
-Wert gesetzt werden kann — ein weiterer Längenwert kann optional direkt vor dem Farbwert gesetzt werden, dies ist ein Ausbreitungsradius. Wenn gesetzt, wird der Schatten größer als der ursprüngliche Kasten. Es wird nicht sehr häufig verwendet, ist aber erwähnenswert.
Filter
Während Sie die Komposition eines Bildes mit CSS nicht ändern können, gibt es einige kreative Dinge, die Sie tun können. Eine sehr interessante Eigenschaft, die Ihnen helfen kann, Interesse an Ihren Designs zu wecken, ist die filter
-Eigenschaft. Diese Eigenschaft ermöglicht Photoshop-ähnliche Filter direkt aus CSS.
Im folgenden Beispiel haben wir zwei verschiedene Werte für den Filter verwendet. Der erste
ist blur()
— diese Funktion kann einen Wert annehmen, der angibt, wie stark das Bild verschwommen sein soll.
Der zweite ist grayscale()
; durch die Verwendung eines Prozentsatzes legen wir fest, wie viel Farbe entfernt werden soll.
Spielen Sie mit den Prozent- und Pixelparametern im Beispiel unten, um zu sehen, wie sich die Bilder verändern. Sie könnten die Werte auch für andere austauschen. Versuchen Sie contrast(200%)
, invert(100%)
oder hue-rotate(20deg)
im obigen Live-Beispiel. Schauen Sie auf der MDN-Seite für filter
nach, um viele andere Optionen zu finden, die Sie ausprobieren könnten.
<div class="wrapper">
<div class="box">
<img
alt="balloons"
class="blur"
src="https://mdn.github.io/shared-assets/images/examples/balloons.jpg" />
</div>
<div class="box">
<img
alt="balloons"
class="grayscale"
src="https://mdn.github.io/shared-assets/images/examples/balloons.jpg" />
</div>
</div>
img {
height: 100%;
width: 100%;
display: block;
object-fit: cover;
}
.blur {
filter: blur(10px);
}
.grayscale {
filter: grayscale(60%);
}
Sie können Filter auf jedes Element, nicht nur auf Bilder, anwenden. Einige der verfügbaren Filteroptionen tun sehr ähnliche Dinge wie andere CSS-Funktionen, zum Beispiel funktioniert drop-shadow()
in sehr ähnlicher Weise und bietet einen ähnlichen Effekt wie box-shadow
oder text-shadow
. Das wirklich Schöne an Filtern ist jedoch, dass sie auf die exakten Formen des Inhalts innerhalb des Kastens wirken und nicht nur auf den Kasten selbst als ein großer Block. Es lohnt sich also, den Unterschied zu kennen.
Im nächsten Beispiel wenden wir unseren Filter auf einen Kasten an und vergleichen ihn mit einem Boxschatten. Wie Sie sehen können, folgt der Drop-Shadow-Filter der exakten Form des Textes und der Rahmenstriche. Der Boxschatten folgt nur dem Quadrat des Kastens.
<p class="filter">Filter</p>
<p class="box-shadow">Box shadow</p>
body {
font-family: sans-serif;
}
p {
margin: 1em 2em;
padding: 20px;
width: 100px;
display: inline-block;
border: 5px dashed red;
}
.filter {
filter: drop-shadow(5px 5px 1px rgb(0 0 0 / 70%));
}
.box-shadow {
box-shadow: 5px 5px 1px rgb(0 0 0 / 70%);
}
Mischmodi
CSS-Mischmodi ermöglichen es uns, Blending-Modi auf Elemente anzuwenden, die einen Mischeffekt angeben, wenn zwei Elemente überlappen — die endgültige Farbe, die für jedes Pixel angezeigt wird, ist das Ergebnis einer Kombination aus der ursprünglichen Pixel-Farbe und der des Pixels in der darunter liegenden Schicht. Mischmodi sind wiederum sehr vertraut für Benutzer von Grafikprogrammen wie Photoshop.
Es gibt zwei Eigenschaften, die in CSS Mischmodi verwenden:
background-blend-mode
, das mehrere Hintergrundbilder und Farben, die auf einem einzigen Element festgelegt sind, miteinander vermischt.mix-blend-mode
, das das Element, auf dem es gesetzt ist, mit den Elementen, mit denen es überlappt — sowohl Hintergrund als auch Inhalt — vermischt.
Sie können viel mehr Beispiele als hier verfügbar auf unserer blend-modes.html Beispielseite finden (siehe Quelldaten), und auf der <blend-mode>
Referenzseite.
Hinweis: Mischmodi sind ebenfalls sehr neu und werden etwas weniger gut unterstützt als Filter. Es gibt noch keine Unterstützung in Edge, und Safari unterstützt nur einige der Mischmodi-Optionen.
background-blend-mode
Lassen Sie uns wieder Beispiele ansehen, um dies besser zu verstehen. Zuerst background-blend-mode
— hier zeigen wir ein paar einfache <div>
s, damit Sie das Original mit der vermischten Version vergleichen können:
<div></div>
<div class="multiply"></div>
Nun etwas CSS — wir fügen dem <div>
ein Hintergrundbild und eine grüne Hintergrundfarbe hinzu:
div {
width: 250px;
height: 130px;
padding: 10px;
margin: 10px;
display: inline-block;
background: url(colorful-heart.png) no-repeat center 20px;
background-color: green;
}
.multiply {
background-blend-mode: multiply;
}
Das Ergebnis, das wir erhalten, ist dieses — Sie können das Original links und den Multiply-Mischmodus rechts sehen:
mix-blend-mode
Schauen wir uns nun mix-blend-mode
an. Hier präsentieren wir die gleichen zwei <div>
s, aber jedes steht nun auf einem einfachen <div>
mit violettem Hintergrund, um zu zeigen, wie die Elemente zusammengefügt werden:
<article>
No mix blend mode
<div></div>
<div></div>
</article>
<article>
Multiply mix
<div class="multiply-mix"></div>
<div></div>
</article>
Hier ist das CSS, mit dem wir dies gestalten werden:
article {
width: 280px;
height: 180px;
margin: 10px;
position: relative;
display: inline-block;
}
div {
width: 250px;
height: 130px;
padding: 10px;
margin: 10px;
}
article div:first-child {
position: absolute;
top: 10px;
left: 0;
background: url(colorful-heart.png) no-repeat center 20px;
background-color: green;
}
article div:last-child {
background-color: purple;
position: absolute;
bottom: -10px;
right: 0;
z-index: -1;
}
.multiply-mix {
mix-blend-mode: multiply;
}
Dies gibt uns die folgenden Ergebnisse:
Sie können hier sehen, dass der Multiply-Mix-Mischmodus nicht nur die beiden Hintergrundbilder miteinander vermischt hat, sondern auch die Farbe des darunter liegenden <div>
.
Hinweis: Machen Sie sich keine Sorgen, wenn Sie einige der oben genannten Layout-Eigenschaften nicht verstehen, wie position
, top
, bottom
, z-index
, etc. Wir werden diese im Detail in unserem CSS-Layout-Modul behandeln.
CSS-Formen
Obwohl es stimmt, dass alles in CSS ein rechteckiger Kasten ist und Bilder ein physischer rechteckiger Kasten sind, können wir es so aussehen lassen, als ob unser Inhalt um nicht-rechteckige Objekte fließt, indem wir CSS-Formen verwenden.
Die CSS-Formen-Spezifikation ermöglicht das Umfließen von Text um eine nicht-rechteckige Form. Dies ist besonders nützlich, wenn Sie mit einem Bild arbeiten, das weißen Raum enthält, um den Sie Text fließen lassen möchten.
Im Bild unten haben wir einen angenehm runden Ballon. Die eigentliche Datei ist rechteckig, aber indem wir das Bild floaten lassen (Formen gelten nur für gefloatete Elemente) und die shape-outside
-Eigenschaft mit einem Wert von circle(50%)
verwenden, können wir den Effekt erzielen, dass der Text der Linie des Ballons folgt.
<div class="wrapper">
<img
alt="balloon"
src="https://mdn.github.io/shared-assets/images/examples/round-balloon.png" />
<p>
One November night in the year 1782, so the story runs, two brothers sat
over their winter fire in the little French town of Annonay, watching the
grey smoke-wreaths from the hearth curl up the wide chimney. Their names
were Stephen and Joseph Montgolfier, they were papermakers by trade, and
were noted as possessing thoughtful minds and a deep interest in all
scientific knowledge and new discovery. Before that night—a memorable night,
as it was to prove—hundreds of millions of people had watched the rising
smoke-wreaths of their fires without drawing any special inspiration from
the fact.
</p>
</div>
body {
font-family: sans-serif;
}
img {
float: left;
shape-outside: circle(50%);
}
Die Form in diesem Beispiel reagiert nicht auf den Inhalt der Bilddatei. Stattdessen nimmt die Kreisfunktion ihren Mittelpunkt von der Mitte der Bilddatei, als ob wir einen Zirkel in die Mitte der Datei gesetzt und einen Kreis gezeichnet hätten, der in die Datei passt. Es ist dieser Kreis, um den der Text fließt.
Hinweis: In Firefox können Sie die DevTools Shapes Inspector verwenden, um Formen zu inspizieren.
Die circle()
-Funktion ist nur eine von einigen grundlegenden Formen, die definiert sind, aber es gibt eine Reihe verschiedener Möglichkeiten, Formen zu erstellen. Für weitere Informationen und Beispielcode zu CSS-Formen, sehen Sie sich die Leitfaden zu CSS-Formen auf MDN an.
-webkit-background-clip: text
Ein weiteres Feature, das wir kurz erwähnen wollten, ist der text
-Wert für background-clip
. Wenn er zusammen mit der proprietären -webkit-text-fill-color: transparent;
-Funktion verwendet wird, ermöglicht dies das Zuschneiden von Hintergrundbildern auf die Form des Textelements, was einige schöne Effekte ergeben kann. Dies ist kein offizieller Standard, wurde jedoch in mehreren Browsern implementiert, da er beliebt und von Entwicklern recht weit verbreitet verwendet wird. Bei Verwendung in diesem Kontext würden beide Eigenschaften ein -webkit-
-Vendor-Präfix erfordern, auch für nicht auf WebKit/Chrome-basierte Browser.
Sie können dies im folgenden Live-Beispiel in Aktion sehen:
<h2>WOW</h2>
<h2 class="text-clip">WOW</h2>
h2 {
color: white;
display: inline-block;
background: url(colorful-heart.png) no-repeat center;
}
.text-clip {
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
}
Warum haben andere Browser ein -webkit-
Präfix implementiert? Hauptsächlich aus Gründen der Browser-Kompatibilität — so viele Webentwickler haben begonnen, Websites mit -webkit-
Präfixen zu implementieren, dass es begann, so auszusehen, als ob die anderen Browser fehlerhaft wären, während sie tatsächlich den Standards folgten. So waren sie gezwungen, einige solcher Funktionen zu implementieren. Dies verdeutlicht die Gefahr der Verwendung von nicht standardmäßigen und/oder mit Präfixen versehenen CSS-Funktionen in Ihrer Arbeit — sie verursachen nicht nur Probleme mit der Browser-Kompatibilität, sondern sind auch Änderungen unterworfen, sodass Ihr Code jederzeit brechen könnte. Es ist viel besser, sich an die Standards zu halten.
Wenn Sie solche Funktionen in Ihrer Produktionsarbeit verwenden möchten, stellen Sie sicher, dass Sie über alle Browser hinweg gründlich testen und überprüfen, dass die Website auch dann noch nutzbar ist, wenn diese Funktionen nicht funktionieren.