纯css:一个好玩的按钮边框动态动画

思路:使用伪元素+动画来实现

代码:

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    * {
      padding: 0;
      margin: 0;
    }
  
    body {
      background: #000;
    }
  
    .wrap {
      width: 400px;
      height: 400px;
      display: flex;
      justify-content: center;
      align-items: center;
    }
  
    .btn {
      width: 80px;
      height: 30px;
      border-radius: 5px;
      color: #fff;
      text-align: center;
      position: relative;
      overflow: hidden;
    }
  
    /* 这是需要动画的一个div */
    .btn::before {
      display: inline-block;
      background: red;
      content: '';
      width: 80px;
      height: 80px;
      position: absolute;
      left: 50%;
      top: 50%;
      z-index: -2;
      transform-origin: left top;
      animation: 5s animate 0s infinite;
    }
  
    /* 这是需要把动画的div隐藏一部分的div*/
    .btn::after {
      display: inline-block;
      background: #3f3f3f;
      border-radius: 5px;
      content: '';
      --w: 2px;
      left: var(--w);
      top: var(--w);
      width: calc(100% - 2 * var(--w));
      height: calc(100% - 2 * var(--w));
      position: absolute;
      z-index: -1;
    }
  
    @keyframes animate {
      from {
        transform: rotate(0deg)
      }
  
      to {
        transform: rotate(360deg)
      }
    }
  </style>
  </head>

<body>
  <!-- 写一个按钮的边框在移动的css -->
  <div class="wrap">
    <span class="btn">Button</span>
  </div>
  </body>

</html>
相关推荐
-dcr2 分钟前
50.智能体
前端·javascript·人工智能·ai·easyui
行者9611 分钟前
Flutter跨平台开发适配OpenHarmony:进度条组件的深度实践
开发语言·前端·flutter·harmonyos·鸿蒙
云和数据.ChenGuang12 分钟前
Uvicorn 是 **Python 生态中用于运行异步 Web 应用的 ASGI 服务器**
服务器·前端·人工智能·python·机器学习
IT_陈寒14 分钟前
SpringBoot 3.0实战:这5个新特性让你的开发效率提升50%
前端·人工智能·后端
winfredzhang21 分钟前
从零构建:基于 Node.js 的全栈视频资料管理系统开发实录
css·node.js·html·音视频·js·收藏,搜索,缩略图
遗憾随她而去.22 分钟前
Webpack 面试题
前端·webpack·node.js
我要敲一万行23 分钟前
前端文件上传
前端·javascript
恋猫de小郭25 分钟前
Tailwind 因为 AI 的裁员“闹剧”结束,而 AI 对开源项目的影响才刚刚开始
前端·flutter·ai编程
要加油哦~26 分钟前
算法 | 整理数据结构 | 算法题中,JS 容器的选择
前端·javascript·算法
一只小bit26 分钟前
Qt 重要控件:多元素控件、容器类控件及布局管理器
前端·c++·qt