CSS八种让人眼前一亮的HOVER效果

做~自己de王妃 提交于 2020-12-05 20:54:37
 来源: https://juejin.im/post/6861501624993447950
译自: https://www.blog.duomly.com/html-button-hover-effects/

一.发送效果

HTML

<div id="send-btn">
  <button>
    // 这里是一个svg的占位
    Send
  </button>
</div>

CSS

#send-btn{
  display: flex;
  align-items: center;
  justify-content: center;
  height100vh;
}

button {
  background#5f55af;
  border0;
  border-radius5px;
  padding10px 30px 10px 20px;
  color: white;
  text-transform: uppercase;
  font-weight: bold;
}

button svg {
  display: inline-block;
  vertical-align: middle;
  padding-right5px;
}

button:hover svg {
  animation: fly 2s ease 1;
}

@keyframes fly {
  0% {
    transformtranslateX(0%);
  }

  50% {
    transformtranslateX(300%);
  }

  100% {
    transformtranslateX(0);
  }
}

GIF图

hover_effect_send

二.霓虹效果

HTML

<div id="neon-btn">
  <button class="btn one">Hover me</button>
  <button  class="btn two">Hover me</button>
  <button  class="btn three">Hover me</button>
</div>

CSS

#neon-btn {
  display: flex;
  align-items: center;
  justify-content: space-around;
  height100vh;
  background#031628
}

.btn {
  border1px solid;
  background-color: transparent;
  text-transform: uppercase;
  font-size14px;
  padding10px 20px;
  font-weight300;
}

.one {
  color#4cc9f0;
}

.two {
  color#f038ff
}

.three {
  color#b9e769;
}

.btn:hover {
  color: white;
  border0;
}

.one:hover {
  background-color#4cc9f0;
  -webkit-box-shadow10px 10px 99px 6px rgba(76,201,240,1);
  -moz-box-shadow10px 10px 99px 6px rgba(76,201,240,1);
  box-shadow10px 10px 99px 6px rgba(76,201,240,1);
}

.two:hover {
  background-color#f038ff;
  -webkit-box-shadow10px 10px 99px 6px rgba(240, 56, 255, 1);
  -moz-box-shadow10px 10px 99px 6px rgba(240, 56, 255, 1);
  box-shadow10px 10px 99px 6px rgba(240, 56, 255, 1);
}

.three:hover {
  background-color#b9e769;
  -webkit-box-shadow10px 10px 99px 6px rgba(185, 231, 105, 1);
  -moz-box-shadow10px 10px 99px 6px rgba(185, 231, 105, 1);
  box-shadow10px 10px 99px 6px rgba(185, 231, 105, 1);
}

GIF图

hover_effect_neon

三.边框效果

HTML

<div id="draw-border">
  <button>Hover me</button>
</div>

CSS

#draw-border {
  display: flex;
  align-items: center;
  justify-content: center;
  height100vh;
}

button {
  border0;
  background: none;
  text-transform: uppercase;
  color#4361ee;
  font-weight: bold;
  position: relative;
  outline: none;
  padding10px 20px;
  box-sizing: border-box;
}

button::beforebutton::after {
  box-sizing: inherit;
  position: absolute;
  content'';
  border2px solid transparent;
  width0;
  height0;
}

button::after {
  bottom0;
  right0;
}

button::before {
  top0;
  left0;
}

button:hover::beforebutton:hover::after {
  width100%;
  height100%;
}

button:hover::before {
  border-top-color#4361ee;
  border-right-color#4361ee;
  transition: width 0.3s ease-out, height 0.3s ease-out 0.3s;
}

button:hover::after {
  border-bottom-color#4361ee;
  border-left-color#4361ee;
  transition: border-color 0s ease-out 0.6s, width 0.3s ease-out 0.6s, height 0.3s ease-out 1s;
}

GIF效果

hover_effect_draw

四.圆形效果

HTML

<div id="circle-btn">
  <div class="btn-container">
    // 这里有一个svg元素
    <button>Hover me</button>
  </div>
</div>

CSS

#circle-btn { 
  display: flex;
  align-items: center;
  justify-content: center;
  height100vh;
}

.btn-container {
  position: relative;  
}

button {
  border0;
  border-radius50px;
  color: white;
  background#5f55af;
  padding15px 20px 16px 60px;
  text-transform: uppercase;
  backgroundlinear-gradient(to right, #f72585 50%, #5f55af 50%);
  background-size200% 100%;
  background-position: right bottom;
  transition:all 2s ease;
}

svg {
  background#f72585;
  padding8px;
  border-radius50%;
  position: absolute;
  left0;
  top0%;
}

button:hover {
   background-position: left bottom;
}

GIF图

hover_effect_circle

五.圆角效果

HTML

<div id="border-btn">
  <button>Hover me</button>
</div>

CSS

#border-btn { 
  display: flex;
  align-items: center;
  justify-content: center;
  height100vh;
}

button {
  border0;
  border-radius10px;
  background#2ec4b6;
  text-transform: uppercase;
  color: white;
  font-size16px;
  font-weight: bold;
  padding15px 30px;
  outline: none;
  position: relative;
  transition: border-radius 3s;
  -webkit-transition: border-radius 3s;
}

button:hover {
   border-bottom-right-radius50px;
   border-top-left-radius50px;
   border-bottom-left-radius10px;
   border-top-right-radius10px;
}

GIF图

hover_effect_radius

六.冰冻效果

HTML

<div id="frozen-btn">
  <button class="green">Hover me</button>
  <button class="purple">Hover me</button>
</div>

CSS

#frozen-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  height100vh;
}

button {
  border0;
  margin20px;
  text-transform: uppercase;
  font-size20px;
  font-weight: bold;
  padding15px 50px;
  border-radius50px;
  color: white;
  outline: none;
  position: relative;
}

button:before{
  content'';
  display: block;
  backgroundlinear-gradient(to left, rgba(255, 255, 255, 0) 50%rgba(255, 255, 255, 0.4) 50%);
  background-size210% 100%;
  background-position: right bottom;
  height100%;
  width100%;
  position: absolute;
  top0;
  bottom:0;
  right:0;
  left0;
  border-radius50px;
  transition: all 1s;
  -webkit-transition: all 1s;
}

.green {
   background-imagelinear-gradient(to right, #25aae1, #40e495);
   box-shadow0 4px 15px 0 rgba(49, 196, 190, 0.75);
}

.purple {
   background-imagelinear-gradient(to right, #6253e1, #852D91);
   box-shadow0 4px 15px 0 rgba(236, 116, 149, 0.75);
}
  
.purple:hover:before {
  background-position: left bottom;
}

.green:hover:before {
  background-position: left bottom;
}

GIF图

hover_effect_frozen

七.闪亮效果

HTML

<div id="shiny-shadow">
  <button><span>Hover me</span></button>
</div>

CSS

#shiny-shadow {
  display: flex;
  align-items: center;
  justify-content: center;
  height100vh;
  background#1c2541;
}

button {
  border2px solid white;
  background: transparent;
  text-transform: uppercase;
  color: white;
  padding15px 50px;
  outline: none;
  overflow: hidden;
  position: relative;
}

span {
  z-index20;  
}

button:after {
  content'';
    display: block;
    position: absolute;
    top: -36px;
    left: -100px;
    background: white;
    width50px;
    height125px;
    opacity20%;
    transformrotate(-45deg);
}

button:hover:after {
  left120%;
  transition: all 600ms cubic-bezier(0.3, 1, 0.2, 1);
   -webkit-transition: all 600ms cubic-bezier(0.3, 1, 0.2, 1);
}

GIF图

hover_effect_shiny

八.加载效果

HTML

<div id="loading-btn">
  <button><span>Hover me</span></button>
</div>

CSS

#loading-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  height100vh;
}

button {
  background: transparent;
  border0;
  border-radius0;
  text-transform: uppercase;
  font-weight: bold;
  font-size20px;
  padding15px 50px;
  position: relative;
}

button:before {
  transition: all 0.8s cubic-bezier(0.7, -0.5, 0.2, 2);
  content'';
  width1%;
  height100%;
  background#ff5964;
  position: absolute;
  top0;
  left0;
}

button span {
  mix-blend-mode: darken;
}

button:hover:before {
  background#ff5964;
  width100%;
}

GIF图

hover_effect_load

总结

巧用伪元素:before:after等,让你的页面按钮眼前一亮。原文链接:blog.duomly.com/html-button-hover-effects/。更多内容:https://github.com/reng99/blogs

最后

欢迎关注「前端瓶子君」,回复「交流」加入前端交流群!
欢迎关注「前端瓶子君」,回复「算法」自动加入,从0到1构建完整的数据结构与算法体系!
在这里(算法群),你可以每天学习一道大厂算法编程题(阿里、腾讯、百度、字节等等)或 leetcode,瓶子君都会在第二天解答哟!
另外,每周还有手写源码题,瓶子君也会解答哟!
》》面试官也在看的算法资料《《
“在看和转发” 就是最大的支持

本文分享自微信公众号 - 前端瓶子君(pinzi_com)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!