Hagamos ese efecto de texto con gradiente animado con propiedades personalizadas centradas y recorte de fondo
Ve a CodePen y crea un nuevo editor.
Crea el marcado para tu texto. Usemos un encabezado con la palabra “Rápido”:
<h1 class="boujee-text">Hello!</h1>
Luego, le daremos a nuestro body
un background-color
más oscuro:
body {
display: grid;
place-items: center;
min-height: 100vh;
background: hsl(0 0% 20%);
}
Aumenta el font-size
en nuestro texto. Usa clamp
para que sea responsivo:
.boujee-text {
font-size: clamp(3rem, 25vmin, 8rem);
}
Crea dos propiedades personalizadas para los colores que usaremos. Aplica un linear-gradient
al background
con esos colores y rótalo 90 grados:
.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 propiedad personalizada que puedas usar para el tamaño de fondo horizontal. Úsalo para 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%;
}
Para recortar el fondo en el texto, establece color
en transparent
y configura 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;
}
En este punto, puedes dejarlo así y experimentar con background-position
y el gradiente que se usa en background-image
. También puedes animar ese gradiente en el texto. Primero, define un fotograma clave para la animación. Se usará la propiedad personalizada --bg-size
que definiste antes. Un buen ejemplo de propiedades personalizadas centradas que te facilitan el mantenimiento.
@keyframes move-bg {
to {
background-position: var(--bg-size) 0;
}
}
Luego, aplica la animación con 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;
}
Para ir más allá, puedes unir tu código de animación en una consulta de contenido multimedia para respetar las preferencias de movimiento del usuario:
@media (prefers-reduced-motion: no-preference) {
.boujee-text {
animation: move-bg 8s linear infinite;
}
@keyframes move-bg {
to {
background-position: var(--bg-size) 0;
}
}
}
¡Listo! 🎉 Creaste texto con gradiente animado con CSS usando propiedades personalizadas con alcance y background-clip
.
Aquí tienes esta sugerencia en forma de video rápido. ⚡️
¿Prefieres esto mediante formato de tweet? 🐦
Que tengas un buen día. ʕ •ᴥ•ʔ
Imagen hero de Vladislav Klapin en Unsplash