欢迎访问 ajycc20のblog

Button-hover 02

HTML

<div class="container">
  <a href="#">
    <span></span>
    <span></span>
    <span></span>
    <span></span>
    Button
  </a>
</div>  

CSS

body {
  margin: 0;
  padding: 0;
  background: #34495e;
  font-family: sans-serif;
}
.container {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
a {
  position: absolute;
  transform: translate(-50%, -50%);
  padding: 20px 40px;
  color: #3498db;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 26px;
  text-decoration: none;
  box-shadow: 0 0 40px rgba(0, 0, 0, .5);
  /* overflow: hidden; */
}
a::before {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  bottom: 2px;
  width: 50%;
  background: rgba(255, 255, 255, .2);
}
a:hover span:nth-child(1) {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(to right, #34495e,#3498db);
  animation: span1 2s linear infinite;
}
@keyframes span1 {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(100%);
  }
}
a:hover span:nth-child(2) {
  position: absolute;
  top: 0;
  right: 0;
  width: 2px;
  height: 100%;
  background: linear-gradient(to bottom, #34495e,#3498db);
  animation: span2 2s linear infinite;
}
@keyframes span2 {
  0% {
    transform: translateY(-100%);
  }
  100% {
    transform: translateY(100%);
  }
}
a:hover span:nth-child(3) {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(to left, #34495e,#3498db);
  animation: span3 2s linear infinite;
}
@keyframes span3 {
  0% {
    transform: translate(100%);
  }
  100% {
    transform: translateX(-100%);
  }
}
a:hover span:nth-child(4) {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 2px;
  height: 100%;
  background: linear-gradient(to top, #34495e,#3498db);
  animation: span4 2s linear infinite;
}
@keyframes span4 {
  0% {
    transform: translateY(100%);
  }
  100% {
    transform: translateY(-100%);
  }
}

Demo

Description

nth-child(n): 选择对应的第n个元素
background: linear-gradient: 背景色设置渐变色
animation: span1 2s linear infinite;: 设置动画 持续2s 速度恒定 无限循环

动画效果,从X为-100%位置-> 100%

@keyframes  span1 {
0% {
    transform: translateX(-100%);
    }
100% {
    transform: translateX(100%);
    }
}
img

4 评论
jinjianh • 2019-08-23
回复 删除

老哥你这滚动条怕是有点问题哦

ajycc20 • 2019-08-23
回复 删除

一开始没想好怎么显示好看 干脆就直接显示成轮廓了

Vanessa • 2019-08-23
回复 删除

不要重复可能会好一点

ajycc20 • 2019-08-23
回复 删除

加 overflow:hidden 倒是可以隐藏 但是一开始是想让每个边的线条刚好有一种自然的感觉 现在勉强这样吧 不知道怎么改了