css实现按钮边框旋转

先上效果图

本质:一个矩形在两个矩形互相重叠遮盖形成的缝隙中旋转形成,注意css属性z-index层级关系

直接上代码

html 复制代码
  <div class="bg">
    <div class="button">按钮</div>
  </div>
  
  <style>
	.bg {
	  width: 100%;
	  height: 100vh;
	  background-color: #000;
	  display: flex;
	  align-items: center;
	  justify-content: center;
	}


	@keyframes run {
	  0% {
	    transform: rotate(0);
	  }
	  100% {
	    transform: rotate(360deg);
	  }
	}

	.button {
	  width: 200px;
	  height: 100px;
	  display: flex;
	  align-items: center;
	  justify-content: center;
	  position: relative;
	  overflow: hidden;  /* 关键属性 */
	  color: #fff;
	  z-index: 1;
	  border-radius: 4px;
	}
	.button::before {
	  content: "";
	  width: 200%;
	  height: 200%;  /* 调整此处宽高控制旋转边框的长度 */
	  position: absolute;
	  background: linear-gradient(135deg, #ff00cc, #ffcc00, #00ffcc, #ff0066);
	  z-index: -2;
	  left: 50%;
	  top: 50%;
	  animation: run 1.5s linear infinite;
	  transform-origin: left top;
	}
	.button::after {
	  content: "";
	  position: absolute;
	  --w: 2px; /* 控制宽度 */
	  width: calc(100% - 2 * var(--w));
	  height: calc(100% - 2 * var(--w));
	  left: var(--w);
	  top: var(--w);
	  background: #000;
	  z-index: -1;
	  border-radius: inherit;
	}
  </style>
相关推荐
Hilaku1 天前
做中后台业务,为什么我不建议你用 Tailwind CSS?
前端·css·代码规范
有意义1 天前
【面试复盘】前端底层原理与 React 核心机制深度梳理
前端·react.js·面试
二十一_1 天前
LangChain 教程 05|模型配置:AI 的大脑与推理引擎
前端·langchain
kerli1 天前
Compose 组件:BoxWithConstraints作用及其原理
android·前端
LovroMance1 天前
消息总线 + 可插拔的消息插件管理系统
前端
Lee川1 天前
React Router 实战指南:构建现代化前端路由系统
前端·react.js·架构
薛纪克1 天前
前端自动化测试的 Spec 模式:用 Kiro Power 实现从需求到脚本的全链路自动化
前端·自动化测试·ai·kiro
YAwu111 天前
HTML语义化渲染与CSS优先级机制的技术解析
前端
MgArcher1 天前
Python高级特性:filter() 函数完全指南
前端·后端
han_1 天前
JavaScript设计模式(十):模板方法模式实现与应用
前端·javascript·设计模式