CSS 快速提示!渐变文本动画

我们使用限定范围的自定义属性和背景剪辑来制作动画渐变文本效果

您可以访问 CodePen,然后创建新钢笔。

为文本创建标记。让我们使用包含“Speedy”一词的标题:

<h1 class="boujee-text">Hello!</h1>

然后,为 body 指定颜色更深的 background-color

body {
  display: grid;
  place-items: center;
  min-height: 100vh;
  background: hsl(0 0% 20%);
}

提升文本的 font-size。使用 clamp 可使其具备自适应能力:

.boujee-text {
  font-size: clamp(3rem, 25vmin, 8rem);
}

为要使用的颜色创建两个自定义属性。使用这些颜色将 linear-gradient 应用于 background,并将其旋转 90 度:

.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%;
}

创建一个可用于水平背景大小的自定义属性。将其用于 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%;
}

如需将背景裁剪为文本,请将 color 设置为 transparent,并设置 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;
}

此时,您可以将其留在那里,并使用 background-positionbackground-image 中使用的渐变进行实验。或者,您也可以在文本上添加动画效果。首先,为动画定义一个关键帧。这将使用您之前定义的 --bg-size 自定义属性。限定范围的自定义属性就是一个很好的例子,它可以让您更轻松地进行维护。

@keyframes move-bg {
  to {
    background-position: var(--bg-size) 0;
  }
}

然后使用 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;
}

此外,您可以将动画代码封装在媒体查询中,以遵循用户的动作偏好:

@media (prefers-reduced-motion: no-preference) {
  .boujee-text {
    animation: move-bg 8s linear infinite;
  }
  @keyframes move-bg {
    to {
      background-position: var(--bg-size) 0;
    }
  }
}

已完成!🎉? 您已经使用作用域自定义属性和 background-clip 使用 CSS 创建了一些动画渐变文本。

以快速视频形式提供这条提示!⚡️

更喜欢在 Tweet 表单中发布的信息?🐦

棒极了! •ᴥ•"><

主打图片,作者:Vladislav Klapin,来源:Unsplash