Erstellen Sie ausgefallene Boxen
CSS-Boxen sind die Bausteine jeder Webseite, die mit CSS gestaltet ist. Sie ansprechend zu gestalten, ist sowohl unterhaltsam als auch herausfordernd. Es ist unterhaltsam, weil es darum geht, eine Designidee in funktionierenden Code umzuwandeln; es ist herausfordernd aufgrund der Einschränkungen von CSS. Lassen Sie uns einige ausgefallene Boxen erstellen.
Bevor wir uns mit den praktischen Aspekten befassen, stellen Sie sicher, dass Sie mit dem CSS-Boxmodell vertraut sind. Es ist auch eine gute Idee, aber keine Voraussetzung, sich mit einigen Grundlagen des CSS-Layouts vertraut zu machen.
Auf der technischen Seite geht es beim Erstellen ausgefallener Boxen darum, die CSS-Eigenschaften für Umrandung und Hintergrund zu beherrschen und wie man sie auf eine gegebene Box anwendet. Aber abgesehen von den Techniken geht es auch darum, Ihre Kreativität zu entfalten. Es wird nicht an einem Tag erledigt sein, und einige Webentwickler verbringen ihr ganzes Leben damit, dies mit Freude zu tun.
Wir werden viele Beispiele sehen, aber wir werden immer an dem einfachsten HTML-Element arbeiten, einem einfachen Element:
<div class="fancy">Hi! I want to be fancy.</div>
Okay, das ist ein sehr kleines Stück HTML, was können wir an diesem Element anpassen? All das Folgende:
- Seine Boxmodell-Eigenschaften:
width
,height
,padding
,border
, usw. - Seine Hintergrund-Eigenschaften:
background
,background-color
,background-image
,background-position
,background-size
, usw. - Seine Pseudo-Elemente:
::before
und::after
- und einige Nebeneigenschaften wie:
box-shadow
,rotate
,outline
, usw.
Wir haben also einen sehr großen Spielplatz. Lassen Sie den Spaß beginnen.
Anpassung des Boxmodells
Allein das Boxmodell ermöglicht es uns, einige grundlegende Dinge zu tun, wie einfache Umrandungen hinzuzufügen, Quadrate zu erstellen usw. Es wird interessant, wenn Sie die Eigenschaften bis zum Limit ausreizen, indem Sie negative padding
und/oder margin
verwenden oder border-radius
größer als die eigentliche Größe der Box machen.
Kreise erstellen
Das ist etwas, das sowohl sehr einfach als auch sehr lustig ist. Die Eigenschaft border-radius
dient dazu, abgerundete Ecken auf Boxen anzuwenden, aber was passiert, wenn die Radiusgröße gleich oder größer als die tatsächliche Breite der Box ist?
.fancy {
/* Within a circle, centered text looks prettier. */
text-align: center;
/* Let's avoid our text touching the border. As
our text will still flow in a square, it looks
nicer that way, giving the feeling that it's a "real"
circle. */
padding: 1em;
/* The border will make the circle visible.
You could also use a background, as
backgrounds are clipped by border radius */
border: 0.5em solid black;
/* Let's make sure we have a square.
If it's not a square, we'll get an
ellipsis rather than a circle */
width: 4em;
height: 4em;
/* and let's turn the square into a circle */
border-radius: 100%;
}
Ja, wir erhalten einen Kreis:
Hintergründe
Wenn wir von einer ausgefallenen Box sprechen, sind die Kerneigenschaften, die dafür verantwortlich sind, background-* Eigenschaften. Wenn Sie anfangen, mit Hintergründen zu spielen, ist es, als ob Ihre CSS-Box zu einer leeren Leinwand wird, die Sie füllen können.
Bevor wir zu einigen praktischen Beispielen kommen, treten wir einen Schritt zurück, da es zwei Dinge gibt, die Sie über Hintergründe wissen sollten.
- Es ist möglich, mehrere Hintergründe auf einer einzigen Box zu setzen. Sie sind wie Schichten übereinander gestapelt.
- Hintergründe können entweder Vollfarben oder Bilder sein: Eine Vollfarbe füllt immer die gesamte Oberfläche, aber Bilder können skaliert und positioniert werden.
Okay, lassen Sie uns Spaß mit Hintergründen haben:
.fancy {
padding: 1em;
width: 100%;
height: 200px;
box-sizing: border-box;
/* At the bottom of our background stack,
let's have a misty grey solid color */
background-color: #e4e4d9;
/* We stack linear gradients on top of each
other to create our color strip effect.
As you will notice, color gradients are
considered to be images and can be
manipulated as such */
background-image: linear-gradient(175deg, rgb(0 0 0 / 0%) 95%, #8da389 95%),
linear-gradient( 85deg, rgb(0 0 0 / 0%) 95%, #8da389 95%),
linear-gradient(175deg, rgb(0 0 0 / 0%) 90%, #b4b07f 90%),
linear-gradient( 85deg, rgb(0 0 0 / 0%) 92%, #b4b07f 92%),
linear-gradient(175deg, rgb(0 0 0 / 0%) 85%, #c5a68e 85%),
linear-gradient( 85deg, rgb(0 0 0 / 0%) 89%, #c5a68e 89%),
linear-gradient(175deg, rgb(0 0 0 / 0%) 80%, #ba9499 80%),
linear-gradient( 85deg, rgb(0 0 0 / 0%) 86%, #ba9499 86%),
linear-gradient(175deg, rgb(0 0 0 / 0%) 75%, #9f8fa4 75%),
linear-gradient( 85deg, rgb(0 0 0 / 0%) 83%, #9f8fa4 83%),
linear-gradient(175deg, rgb(0 0 0 / 0%) 70%, #74a6ae 70%),
linear-gradient( 85deg, rgb(0 0 0 / 0%) 80%, #74a6ae 80%);
}
Hinweis: Verläufe können auf sehr kreative Weise verwendet werden. Wenn Sie einige kreative Beispiele sehen möchten, schauen Sie sich Lea Verou's CSS-Muster an. Wenn Sie mehr über Verläufe erfahren möchten, werfen Sie einen Blick in unseren speziellen Artikel.
Pseudo-Elemente
Beim Stylen einer einzigen Box könnten Sie sich eingeschränkt fühlen und sich wünschen, mehr Boxen zu haben, um noch erstaunlichere Stile zu schaffen. Meistens führt dies dazu, das DOM zu verschmutzen, indem zusätzliche HTML-Elemente nur zu Zwecken der Stilgestaltung hinzugefügt werden. Auch wenn es notwendig ist, wird es als schlechte Praxis angesehen. Eine Lösung, um solche Fallstricke zu vermeiden, ist die Verwendung von CSS-Pseudo-Elementen.
Eine Wolke
Lassen Sie uns ein Beispiel sehen, indem wir unsere Box in eine Wolke verwandeln:
.fancy {
text-align: center;
/* Same trick as previously used to make circles */
box-sizing: border-box;
width: 150px;
height: 150px;
padding: 80px 1em 0 1em;
/* We make room for the "ears" of our cloud */
margin: 0 100px;
position: relative;
background-color: #a4c9cf;
/* Well, actually we are not making a full circle
as we want the bottom of our cloud to be flat.
Feel free to tweak this example to make a cloud
that isn't flat at the bottom ;) */
border-radius: 100% 100% 0 0;
}
/* Those are common style that apply to both our ::before
and ::after pseudo elements. */
.fancy::before,
.fancy::after {
/* This is required to be allowed to display the
pseudo-elements, event if the value is an empty
string */
content: "";
/* We position our pseudo-elements on the left and
right sides of the box, but always at the bottom */
position: absolute;
bottom: 0;
/* This makes sure our pseudo-elements will be below
the box content whatever happens. */
z-index: -1;
background-color: #a4c9cf;
border-radius: 100%;
}
.fancy::before {
/* This is the size of the clouds left ear */
width: 125px;
height: 125px;
/* We slightly move it to the left */
left: -80px;
/* To make sure that the bottom of the cloud
remains flat, we must make the bottom right
corner of the left ear square. */
border-bottom-right-radius: 0;
}
.fancy::after {
/* This is the size of the clouds left ear */
width: 100px;
height: 100px;
/* We slightly move it to the right */
right: -60px;
/* To make sure that the bottom of the cloud
remains flat, we must make the bottom left
corner of the right ear square. */
border-bottom-left-radius: 0;
}
Blockzitat
Ein praktischeres Beispiel für die Verwendung von Pseudo-Elementen ist es, ein schönes Format für HTML-<blockquote>
-Elemente zu erstellen. Sehen wir uns also ein Beispiel mit einem etwas anderen HTML-Schnipsel an (was uns die Gelegenheit bietet, zu sehen, wie man auch das Design lokalisiert):
<blockquote>
People who think they know everything are a great annoyance to those of us who
do. <i>Isaac Asimov</i>
</blockquote>
<blockquote lang="fr">
L'intelligence, c'est comme les parachutes, quand on n'en a pas, on s'écrase.
<i>Pierre Desproges</i>
</blockquote>
Hier kommt unser Stil:
blockquote {
min-height: 5em;
padding: 1em 4em;
font: 1em/150% sans-serif;
position: relative;
background-color: lightgoldenrodyellow;
}
blockquote::before,
blockquote::after {
position: absolute;
height: 3rem;
font:
6rem/100% Georgia,
"Times New Roman",
Times,
serif;
}
blockquote::before {
content: "“";
top: 0.3rem;
left: 0.9rem;
}
blockquote::after {
content: "”";
bottom: 0.3rem;
right: 0.8rem;
}
blockquote:lang(fr)::before {
content: "«";
top: -1.5rem;
left: 0.5rem;
}
blockquote:lang(fr)::after {
content: "»";
bottom: 2.6rem;
right: 0.5rem;
}
blockquote i {
display: block;
font-size: 0.8em;
margin-top: 1rem;
text-align: right;
}
Alles zusammen und mehr
Es ist möglich, einen wunderbaren Effekt zu erzielen, wenn wir all dies zusammen mischen. Irgendwann ist das Erreichen solcher Boxverschönerungen eine Frage der Kreativität, sowohl im Design als auch in der technischen Nutzung von CSS-Eigenschaften. Durch das Erstellen solcher Effekte ist es möglich, optische Täuschungen zu schaffen, die Ihre Boxen lebendig erscheinen lassen können, wie in diesem Beispiel:
Lassen Sie uns einige partielle Schattierungenffekte erstellen. Die Eigenschaft box-shadow
ermöglicht uns, inneres Licht und einen flachen Schattieneffekt zu erzeugen, aber mit etwas zusätzlicher Arbeit wird es möglich, eine natürlichere Geometrie zu schaffen, indem ein Pseudo-Element und die Eigenschaft rotate
, eine der drei individuellen transform
-Eigenschaften, verwendet wird.
.fancy {
position: relative;
background-color: #ffc;
padding: 2rem;
text-align: center;
max-width: 200px;
}
.fancy::before {
content: "";
position: absolute;
z-index: -1;
bottom: 15px;
right: 5px;
width: 50%;
top: 80%;
max-width: 200px;
box-shadow: 0px 13px 10px black;
rotate: 4deg;
}