Als Nächstes erstellen wir den animierten Farbverlaufstexteffekt mit benutzerdefinierten benutzerdefinierten Eigenschaften und einem Hintergrund-Clip.
Wechseln Sie zu CodePen und erstellen Sie einen neuen Stift.
Erstellen Sie das Markup für Ihren Text. Hier sehen Sie eine Überschrift mit dem Wort „Speedy“:
<h1 class="boujee-text">Hello!</h1>
Dann geben wir unserem body
einen dunkleren background-color
:
body {
display: grid;
place-items: center;
min-height: 100vh;
background: hsl(0 0% 20%);
}
Erweitern Sie font-size
in unserem Text. Verwenden Sie clamp
, um sie responsiv zu machen:
.boujee-text {
font-size: clamp(3rem, 25vmin, 8rem);
}
Erstellen Sie zwei benutzerdefinierte Eigenschaften für die zu verwendenden Farben. Wenden Sie ein linear-gradient
auf background
mit diesen Farben an und drehen Sie es um 90 Grad:
.boujee-text {
--color-one: hsl(15 90% 55%);
--color-two: hsl(40 95% 55%);
font-size: clamp(3rem, 25vmin, 8rem);
background: linear-gradient(
90deg,
var(--color-one),
var(--color-two),
var(--color-one)
) 0 0 / 100% 100%;
}
Erstellen Sie eine benutzerdefinierte Eigenschaft, die Sie für die horizontale Hintergrundgröße verwenden können. background-size-x
:
.boujee-text {
--bg-size: 400%;
--color-one: hsl(15 90% 55%);
--color-two: hsl(40 95% 55%);
font-size: clamp(3rem, 25vmin, 8rem);
background: linear-gradient(
90deg,
var(--color-one),
var(--color-two),
var(--color-one)
) 0 0 / var(--bg-size) 100%;
}
Wenn Sie den Hintergrund auf den Text zuschneiden möchten, setzen Sie color
auf transparent
und legen Sie background-clip: text
fest:
.boujee-text {
--bg-size: 400%;
--color-one: hsl(15 90% 55%);
--color-two: hsl(40 95% 55%);
font-size: clamp(3rem, 25vmin, 8rem);
background: linear-gradient(
90deg,
var(--color-one),
var(--color-two),
var(--color-one)
) 0 0 / var(--bg-size) 100%;
color: transparent;
-webkit-background-clip: text;
background-clip: text;
}
Jetzt können Sie es so belassen und mit background-position
und dem Gradienten experimentieren, der in background-image
verwendet wird. Oder Sie können diesen Farbverlauf über Ihren Text hinweg animieren. Definieren Sie zunächst einen Keyframe für die Animation. Dabei wird die benutzerdefinierte Eigenschaft „--bg-size
“ verwendet, die Sie zuvor definiert haben. Ein gutes Beispiel für benutzerdefinierte Eigenschaften auf einen Bereich, die die Wartung erleichtern.
@keyframes move-bg {
to {
background-position: var(--bg-size) 0;
}
}
Wenden Sie dann die Animation mit animation
an:
.boujee-text {
--bg-size: 400%;
--color-one: hsl(15 90% 55%);
--color-two: hsl(40 95% 55%);
font-size: clamp(3rem, 25vmin, 8rem);
background: linear-gradient(
90deg,
var(--color-one),
var(--color-two),
var(--color-one)
) 0 0 / var(--bg-size) 100%;
color: transparent;
background-clip: text;
-webkit-background-clip: text;
animation: move-bg 8s infinite linear;
}
Wenn Sie diesen Schritt weiter ausführen möchten, können Sie Ihren Animationscode in eine Medienabfrage verpacken, um die Bewegungspräferenzen Ihrer Nutzenden zu berücksichtigen:
@media (prefers-reduced-motion: no-preference) {
.boujee-text {
animation: move-bg 8s linear infinite;
}
@keyframes move-bg {
to {
background-position: var(--bg-size) 0;
}
}
}
Fertig. 🎉 Sie haben mit CSS mithilfe von benutzerdefinierten Bereichseigenschaften und background-clip
animierten Farbverlaufstext erstellt.
Hier ist dieser Tipp in seiner schnellen Videoform! ⚡️
Möchtest du die Nachricht als Tweet senden? 🐦
Bleib dran! ạ •ᴥ•ạn
Hero-Image von Vladislav Klapin auf Unsplash