Creiamo un effetto di testo a gradiente animato con proprietà personalizzate basate sull'ambito e clip di sfondo.
Passa a CodePen e crea una nuova penna.
Crea il markup per il testo. Usiamo un'intestazione con la parola "Veloce":
<h1 class="boujee-text">Hello!</h1>
Quindi, assegniamo al nostro body
un background-color
più scuro:
body {
display: grid;
place-items: center;
min-height: 100vh;
background: hsl(0 0% 20%);
}
Aggiungi font-size
al testo. Utilizza clamp
per renderla reattiva:
.boujee-text {
font-size: clamp(3rem, 25vmin, 8rem);
}
Crea due proprietà personalizzate per i colori che useremo. Applica un'istruzione linear-gradient
alla background
utilizzando questi colori e ruotala di 90 gradi:
.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%;
}
Crea una proprietà personalizzata che puoi utilizzare per la dimensione orizzontale dello sfondo. Usala per 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%;
}
Per tagliare lo sfondo al testo, imposta color
su transparent
e imposta background-clip: text
:
.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;
}
A questo punto, puoi lasciarlo lì e sperimentare con background-position
e il gradiente utilizzato in background-image
. In alternativa, puoi animare la sfumatura sul testo. Innanzitutto, definisci un fotogramma chiave per l'animazione. Verrà utilizzata la proprietà personalizzata --bg-size
che hai definito in precedenza. Un buon esempio di proprietà personalizzate con ambito che facilitano la manutenzione.
@keyframes move-bg {
to {
background-position: var(--bg-size) 0;
}
}
Quindi applica l'animazione utilizzando animation
:
.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;
}
Puoi anche includere il codice di animazione in una query supporti per rispettare le preferenze dell'utente relative al movimento:
@media (prefers-reduced-motion: no-preference) {
.boujee-text {
animation: move-bg 8s linear infinite;
}
@keyframes move-bg {
to {
background-position: var(--bg-size) 0;
}
}
}
Fine. 🎉 Hai creato del testo animato a gradiente con il CSS utilizzando le proprietà personalizzate basate sull'ambito e background-clip
.
Ecco questo suggerimento in un video veloce. ⚡️
Preferisci questa versione in tweet? 🐦
Vivi al meglio! ᴕ •ᴥ• famiglia
Immagine hero di Vladislav Klapin su Unsplash