Vamos criar esse efeito de texto com gradiente animado usando propriedades personalizadas com escopo e background-clip.
Acesse o CodePen e crie uma nova caneta.
Crie a marcação do texto. Vamos usar um cabeçalho com a palavra "Speedy":
<h1 class="boujee-text">Hello!</h1>
Em seguida, vamos dar um background-color
mais escuro ao body
:
body {
display: grid;
place-items: center;
min-height: 100vh;
background: hsl(0 0% 20%);
}
Aumente o valor de font-size
no texto. Use clamp
para torná-lo responsivo:
.boujee-text {
font-size: clamp(3rem, 25vmin, 8rem);
}
Crie duas propriedades personalizadas para as cores que vamos usar. Aplique uma linear-gradient
à background
usando essas cores e gire-a em 90 graus:
.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%;
}
Crie uma propriedade personalizada que possa ser usada para o tamanho de plano de fundo horizontal. Use-o 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 o plano de fundo ao texto, defina color
como transparent
e defina 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;
}
Nesse ponto, você pode deixar assim e experimentar o background-position
e o gradiente usado no background-image
. Ou você pode animar esse gradiente no texto. Primeiro, defina um frame-chave para a animação. Isso vai usar a propriedade personalizada --bg-size
que você definiu anteriormente. Um bom exemplo de propriedades personalizadas com escopo que facilitam a manutenção.
@keyframes move-bg {
to {
background-position: var(--bg-size) 0;
}
}
Em seguida, aplique a animação usando 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 além, você pode agrupar o código da animação em uma consulta de mídia para respeitar as preferências de movimento do usuário:
@media (prefers-reduced-motion: no-preference) {
.boujee-text {
animation: move-bg 8s linear infinite;
}
@keyframes move-bg {
to {
background-position: var(--bg-size) 0;
}
}
}
Pronto! 🎉 Você criou textos animados em gradiente com CSS usando propriedades personalizadas com escopo e background-clip
.
Aqui está essa dica em forma de vídeo rápida! ⚡️
Prefere isso em formato de tweet?
Continue se divertindo! ʕ •ᴥ•ʔ
Imagem principal de Vladislav Klapin no Unsplash