分享几个漂亮的宇宙风格的按钮动画效果,让你喜欢上CSS

,它们分别表示太阳和月亮状态,并且它们都有一个state类,用于设置它们的共同样式。两个边框元素:和,它们用于设置按钮的边框样式。

CSS部分:

设置按钮的基本样式:它是一个圆形的容器,它的背景颜色是透明的。它有一个黑色的描边,以及一个白色的阴影。当用户悬停在按钮上时,它会旋转360度。当用户点击按钮时,它会放大并旋转360度,并且它的阴影会变成白色的。两个状态元素的共同样式:它们的位置是绝对定位的,它们都是圆形的,它们都有一个4像素的黑色描边,它们的宽度和高度都是按钮的90%。太阳状态元素的样式:它的背景是一个渐变,当用户悬停在按钮上时,它会显示出来。月亮状态元素的样式:它的背景也是一个渐变。当用户悬停在按钮上时,它的边框会变成太阳状态元素的渐变颜色。两个边框元素的样式:它们的位置是绝对定位的,它们的颜色是按钮的月亮状态的渐变颜色,它们分别有两个不同的大小和不同的动画,它们都是无限循环的动画。最后,使用keyframes关键字定义两个动画rotation_91,使它们旋转360度。3、小行星光圈带环绕

图片[1]-分享几个漂亮的宇宙风格的按钮动画效果,让你喜欢上CSS-天星网创

HTML部分

CSS部分:

button {
  position: relative;
  padding: 18px 55px;
  font-size: 15px;
  font-weight: bold;
  color: #fff;
  background: linear-gradient(87deg, #6d67e4, #7743db, #4e31aa, #6d67e4, #6d67e4);
  background-size: 600% 600%;
  border: 3px solid #7743db;
  border-radius: 8px;
  /* filter: drop-shadow(0 0 4px #9F73AB); */
  box-shadow: inset 0 0 10px 1px #7743db, 0 0 10px 5px #7743db;
  cursor: pointer;
  transition: all 0.5s;
  animation: GradientAnimation 25s ease infinite;
}
button::after {
  content: "";
  position: absolute;
  width: 202px;
  height: 54px;
  top: 0;
  left: -17px;
  border: 5px solid #453c67;
  border-width: 0 2px 4px 0;
  border-radius: 100%;
  filter: drop-shadow(0px 0px 6px rgba(78, 49, 180, 1));
  transform: rotate(-30deg);
  animation: LinerAfter 15s ease infinite;
}
button::before {
  content: "";
  position: absolute;
  width: 200px;
  height: 50px;
  top: 0;
  left: -20px;
  border: 5px solid #6d67e4;
  border-width: 0 12px 8px 4px;
  border-radius: 100%;
  filter: drop-shadow(0px 0px 6px rgba(109, 103, 228, 1));
  /* box-shadow: inset 0 0 10px 1px #4E31AA, 0 0 10px 5px #4E31AA; */
  transform: rotate(-30deg);
  transition: all 0.5s;
  animation: LinerBefore 15s ease infinite;
}
@keyframes GradientAnimation {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}
@keyframes LinerAfter {
  0% {
    left: -27px;
    height: 54px;
  }
  50% {
    left: -7px;
    height: 37px;
  }
  100% {
    left: -27px;
    height: 54px;
  }
}
@keyframes LinerBefore {
  0% {
    left: -30px;
    height: 50px;
  }
  50% {
    left: -10px;
    height: 33px;
  }
  100% {
    left: -30px;
    height: 50px;
  }
}

代码解释:

CSS代码设置了按钮的样式,包括位置、内边距、字体大小、加粗程度、颜色、背景、边框、圆角、光标形状、过渡效果、动画等。其中background属性使用了线性渐变,border属性设置了3px宽度的实线边框,border-radius属性设置了8px的圆角。box-shadow属性设置了两个阴影效果,一个是内阴影,另一个是外阴影。button::after和button::before是button的伪元素,分别表示按钮前面和后面的圆圈。这两个圆圈都是绝对定位,大小、位置、边框、圆角等属性不同,但都使用了drop-shadow滤镜和rotate旋转变换效果。动画效果分别由GradientAnimation、LinerAfter和LinerBefore三个关键帧动画控制,分别设置了不同的属性变化规则,实现了按钮和圆圈的不同的动态效果。

结束

今天的内容就分享到这里,太多了就不利于我们去理解,虽然就三个案例,但是需要我们去慢慢消化和理解,才能成为自己的知识,建议大家还是亲自实现下上述的按钮动画效果,这些案例虽然我们在平常的工作中很少用到,但是如果你接到酷炫的项目,比如某品牌的宣传站点时,我相信这些效果还是能派上用场的。

如果你喜欢这样的文章,请点赞支持下,后续我会持续分享这类的内容,如果太少,我会觉得大家不太喜欢这样的文章,我只能自己私藏了,最后别忘记关注「前端达人」,你的支持将是我分享最大的动力,后续我会持续输出更多内容,敬请期待。

限时特惠:本站每日持续更新海量各大内部创业教程,永久会员享受全站资源免费下载.www.heook.com
站长微信:wc764800

© 版权声明
THE END
喜欢就支持一下吧
点赞11 分享
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称表情代码图片

    暂无评论内容