Créons cet effet de texte animé avec dégradé à l'aide de propriétés personnalisées de portée et de background-clip.
Accédez à CodePen et créez un nouveau canevas.
Créez le balisage de votre texte. Utilisons un en-tête avec le mot « Speedy » :
<h1 class="boujee-text">Hello!</h1>
Ensuite, donnons à notre body
un background-color
plus foncé :
body {
display: grid;
place-items: center;
min-height: 100vh;
background: hsl(0 0% 20%);
}
Augmentez la valeur font-size
de notre texte. Utilisez clamp
pour le rendre responsif :
.boujee-text {
font-size: clamp(3rem, 25vmin, 8rem);
}
Créez deux propriétés personnalisées pour les couleurs que nous allons utiliser. Appliquez un linear-gradient
au background
à l'aide de ces couleurs et faites-le pivoter de 90 degrés :
.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%;
}
Créez une propriété personnalisée que vous pouvez utiliser pour la taille horizontale de l'arrière-plan. Utilisez-la pour 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%;
}
Pour rogner l'arrière-plan sur le texte, définissez color
sur transparent
et 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;
}
À ce stade, vous pouvez laisser le code tel quel et tester le background-position
et le dégradé utilisés dans le background-image
. Vous pouvez également animer ce dégradé dans votre texte. Commencez par définir une image clé pour l'animation. La propriété personnalisée --bg-size
que vous avez définie précédemment sera utilisée. Voici un bon exemple de propriétés personnalisées de portée qui facilitent la maintenance.
@keyframes move-bg {
to {
background-position: var(--bg-size) 0;
}
}
Appliquez ensuite l'animation à l'aide de 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;
}
Pour aller plus loin, vous pouvez encapsuler votre code d'animation dans une requête multimédia afin de respecter les préférences de mouvement de l'utilisateur :
@media (prefers-reduced-motion: no-preference) {
.boujee-text {
animation: move-bg 8s linear infinite;
}
@keyframes move-bg {
to {
background-position: var(--bg-size) 0;
}
}
}
Terminé ! 🎉 Vous avez créé un texte avec dégradé animé en CSS à l'aide de propriétés personnalisées de portée et de background-clip
.
Voici ce conseil sous forme de vidéo rapide : ⚡️
Préférez-vous le formulaire de tweet ? 🐦
Restez génial ! ʕ •ᴥ•ʔ
Image principale par Vladislav Klapin sur Unsplash