纯 CSS 渐变文本动画的快速实现
为文本创建标记。让我们使用包含“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-position
和 background-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 创建了一些动画渐变文本。
视频讲解:
阅读余下内容