CSS-流光特效

前言

在 UI 设计中,合理的动效能极大地提升产品的科技感与交互体验。本文将分享两种高频使用的流光特效:旋转边框流光 (常用于 VIP 会员卡片)与线性扫描流光(常用于加载状态或按钮高亮)。

一、 旋转边框流光 (Border Rotating Glow)

1. 实现效果:

2. 实现原理:背景旋转裁剪


很多同学第一反应是会尝试直接给 `border` 设置渐变,但 CSS 原生 `border` 并不支持动画旋转。

核心黑科技

  1. 底层放一个巨大的、旋转的渐变色块(通常用伪元素实现)。
  2. 上层盖一个略小的容器(按钮主体)。
  3. 父容器设置 overflow: hidden。 这样,转动的渐变色块被裁剪后,露出的那一圈边缘看起来就像流光在游走。

3. 实现代码

HTML 复制代码
<!-- 外层容器包裹按钮 -->
<div class="glow-wrapper">
  <button class="glow-button">流光按钮</button>
</div>


/* 外层容器:负责流光效果 */
.glow-wrapper {
  position: relative; 
  display: inline-block;
  padding: 4px; /* 控制流光边框的宽度 */
  border-radius: 12px;
  overflow: hidden; /* 关键:裁剪旋转的渐变层 */
}

/* 伪元素:旋转的渐变框 */
.glow-wrapper::before {
  content: '';
  position: absolute;
  top: -2px;
  left: -2px;
  right: -2px;
  bottom: -2px;
  background: linear-gradient(
    45deg,
    #0066ff,
    #00ccff,
    #ccff00,
    #ff9900,
    #ff00cc
  );
  border-radius: 12px;
  z-index: -1;
  animation: rotateGlow 3s linear infinite;
}

/* 内部真实按钮 */
.glow-button {
  height: 42px;
  width: 122px;
  line-height: 42px;
  font-size: 18px;
  color: white;
  background: #121212;
  border-radius: 8px; /* 略小于 wrapper 的圆角 */
}
@keyframes rotateGlow {
  0% {
    transform: rotate(0deg);
  }
  40% {
    transform: rotate(180deg);
  }
  60% {
    transform: rotate(180deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

二、 线性扫描流光 (Linear Scanning Glow)

1. 实现效果:

2. 实现原理:背景位移

这种效果模拟了光束扫过物体的视觉感,常用于骨架屏或高级按钮。

核心思路

  • 渐变设计 :设计一个"暗-亮-暗"的 linear-gradient
  • 尺寸放大 :将 background-size 设为 200% 或更大,让"亮点"隐藏在视口之外。
  • 位置动画 :通过改变 background-position,让亮色条从左至右水平穿过。

3. 实现代码

HTML 复制代码
<div class="glow-wrapper">扫描流光</div>

.glow-wrapper {
  position: relative;
  padding: 20px 40px; /* 边框厚度 */
  color: white;
  border-radius: 10px;
  font-weight: 800;
  background: linear-gradient(90deg, transparent, #00dbde, transparent);
  background-size: 200% 100%;
  animation: scan 2s linear infinite;
}

@keyframes scan {
  0% {
    background-position: -200% 0%;
  }
  100% {
    background-position: 200% 0%;
  }
}
相关推荐
LinXunFeng13 小时前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
乘风gg16 小时前
为什么AI 时代来临,大部分人吃不到红利
前端·ai编程·claude
恋猫de小郭17 小时前
Android 限制侧载新进展,谷歌联合国内厂商推验证计划
android·前端·flutter
IT_陈寒17 小时前
Redis内存爆了,原来我漏掉了这个致命配置
前端·人工智能·后端
恋猫de小郭17 小时前
解读 Android 17 全新内存限制,有没有“豁免”后门?
android·前端·flutter
Hyyy18 小时前
理解LLM的基本工作原理:预训练、微调、推理的区别
前端
Gatlin19 小时前
前端逆向与反逆向:一场猫鼠游戏的底层逻辑与实战
前端
Pedantic19 小时前
本地通知(Local Notifications)学习笔记
前端
森蓝情丶20 小时前
我给 AI 搭了个法庭:一个前端仔的 LangGraph 实战全记录
前端·后端
爱勇宝20 小时前
干了近 8 年,一夜之间被裁:AI 时代,程序员最该害怕的不是 AI
前端·后端·程序员