CSS动画效果(鼠标滑过按钮动画)

1.整体效果

https://mmbiz.qpic.cn/sz_mmbiz_gif/EGZdlrTDJa5SXiaicFfsrcric7TJmGO6YddqC4wFPdM7PGzPHuFgvtDS7MIvnLHB4WFaKia0Qh8VCyUaoyHMc2Zltg/640?wx_fmt=gif&from=appmsg&tp=webp&wxfrom=5&wx_lazy=1&wx_co=1

网页设计中的按钮不仅是用户交互的桥梁,更是展示创意和技术的平台。酷炫的鼠标经过动画效果能够显著提升按钮的吸引力,激发用户的点击欲望,从而增加用户参与度。本文将介绍几种常用且引人注目的CSS按钮动画效果

2.完整代码

HTML

<!DOCTYPE html>  
<html lang="en">  
<head>  
    <meta charset="UTF-8">  
    <title>Title</title>  
    <link rel="stylesheet" type="text/css" href="6_1.css">  
</head>  
<body>  
<div class="frame">  
    <button class="custom-btn btn-2">btn02</button>  
    <button class="custom-btn btn-3"><span>btn03</span></button>  
    <button class="custom-btn btn-4"><span>btn04</span></button>  
    <button class="custom-btn btn-5"><span>btn05</span></button>  
    <button class="custom-btn btn-6"><span>btn06</span></button>  
    <button class="custom-btn btn-7"><span>btn07</span></button>  
    <button class="custom-btn btn-8"><span>btn08</span></button>  
</div>  
</body>  
</html>

CSS

body {  
    background: #e0e5ec;  
}  
h1 {  
    position: relative;  
    text-align: center;  
    color: #353535;  
    font-size: 50px;  
    font-family: "Cormorant Garamond", serif;  
}  
  
p {  
    font-family: 'Lato', sans-serif;  
    font-weight: 300;  
    text-align: center;  
    font-size: 18px;  
    color: #676767;  
}  
.frame {  
    width: 50%;  
    margin: 40px auto;  
    text-align: center;  
}  
button {  
    margin: 20px;  
}  
.custom-btn {  
    width: 130px;  
    height: 40px;  
    color: #fff;  
    border-radius: 5px;  
    padding: 10px 25px;  
    font-family: 'Lato', sans-serif;  
    font-weight: 500;  
    background: transparent;  
    cursor: pointer;  
    transition: all 0.3s ease;  
    position: relative;  
    display: inline-block;  
    box-shadow:inset 2px 2px 2px 0px rgba(125, 111, 111, 0.5),  
    7px 7px 20px 0px rgba(0,0,0,.1),  
    4px 4px 5px 0px rgba(0,0,0,.1);  
    outline: none;  
}  
/* 1 */  
  
  
/* 2 */  
.btn-2 {  
    background: rgb(96,9,240);  
    background: linear-gradient(0deg, rgba(96,9,240,1) 0%, rgba(129,5,240,1) 100%);  
    border: none;  
  
}  
.btn-2:before {  
    height: 0%;  
    width: 2px;  
}  
.btn-2:hover {  
    box-shadow: 4px 4px 6px 0 rgba(255,255,255,.5),  
    -4px -4px 6px 0 rgba(116, 125, 136, .5),  
    inset -4px -4px 6px 0 rgba(255,255,255,.2),  
    inset 4px 4px 6px 0 rgba(0, 0, 0, .4);  
}  
  
  
/* 3 */  
.btn-3 {  
    background: rgb(0,172,238);  
    background: linear-gradient(0deg, rgba(0,172,238,1) 0%, rgba(2,126,251,1) 100%);  
    width: 130px;  
    height: 40px;  
    line-height: 42px;  
    padding: 0;  
    border: none;  
  
}  
.btn-3 span {  
    position: relative;  
    display: block;  
    width: 100%;  
    height: 100%;  
}  
.btn-3:before,  
.btn-3:after {  
    position: absolute;  
    content: "";  
    right: 0;  
    top: 0;  
    background: rgba(2,126,251,1);  
    transition: all 0.3s ease;  
}  
.btn-3:before {  
    height: 0%;  
    width: 2px;  
}  
.btn-3:after {  
    width: 0%;  
    height: 2px;  
}  
.btn-3:hover{  
    background: transparent;  
    box-shadow: none;  
}  
.btn-3:hover:before {  
    height: 100%;  
}  
.btn-3:hover:after {  
    width: 100%;  
}  
.btn-3 span:hover{  
    color: rgba(2,126,251,1);  
}  
.btn-3 span:before,  
.btn-3 span:after {  
    position: absolute;  
    content: "";  
    left: 0;  
    bottom: 0;  
    background: rgba(2,126,251,1);  
    transition: all 0.3s ease;  
}  
.btn-3 span:before {  
    width: 2px;  
    height: 0%;  
}  
.btn-3 span:after {  
    width: 0%;  
    height: 2px;  
}  
.btn-3 span:hover:before {  
    height: 100%;  
}  
.btn-3 span:hover:after {  
    width: 100%;  
}  
  
/* 4 */  
.btn-4 {  
    background-color: #4dccc6;  
    background-image: linear-gradient(315deg, #4dccc6 0%, #96e4df 74%);  
    line-height: 42px;  
    padding: 0;  
    border: none;  
}  
.btn-4:hover{  
    background-color: #89d8d3;  
    background-image: linear-gradient(315deg, #89d8d3 0%, #03c8a8 74%);  
}  
.btn-4 span {  
    position: relative;  
    display: block;  
    width: 100%;  
    height: 100%;  
}  
.btn-4:before,  
.btn-4:after {  
    position: absolute;  
    content: "";  
    right: 0;  
    top: 0;  
    box-shadow: 4px 4px 6px 0 rgba(255,255,255,.9),  
    -4px -4px 6px 0 rgba(116, 125, 136, .2),  
    inset -4px -4px 6px 0 rgba(255,255,255,.9),  
    inset 4px 4px 6px 0 rgba(116, 125, 136, .3);  
    transition: all 0.3s ease;  
}  
.btn-4:before {  
    height: 0%;  
    width: .1px;  
}  
.btn-4:after {  
    width: 0%;  
    height: .1px;  
}  
.btn-4:hover:before {  
    height: 100%;  
}  
.btn-4:hover:after {  
    width: 100%;  
}  
.btn-4 span:before,  
.btn-4 span:after {  
    position: absolute;  
    content: "";  
    left: 0;  
    bottom: 0;  
    box-shadow: 4px 4px 6px 0 rgba(255,255,255,.9),  
    -4px -4px 6px 0 rgba(116, 125, 136, .2),  
    inset -4px -4px 6px 0 rgba(255,255,255,.9),  
    inset 4px 4px 6px 0 rgba(116, 125, 136, .3);  
    transition: all 0.3s ease;  
}  
.btn-4 span:before {  
    width: .1px;  
    height: 0%;  
}  
.btn-4 span:after {  
    width: 0%;  
    height: .1px;  
}  
.btn-4 span:hover:before {  
    height: 100%;  
}  
.btn-4 span:hover:after {  
    width: 100%;  
}  
  
/* 5 */  
.btn-5 {  
    width: 130px;  
    height: 40px;  
    line-height: 42px;  
    padding: 0;  
    border: none;  
    background: rgb(255,27,0);  
    background: linear-gradient(0deg, rgba(255,27,0,1) 0%, rgba(251,75,2,1) 100%);  
}  
.btn-5:hover {  
    color: #f0094a;  
    background: transparent;  
    box-shadow:none;  
}  
.btn-5:before,  
.btn-5:after{  
    content:'';  
    position:absolute;  
    top:0;  
    right:0;  
    height:2px;  
    width:0;  
    background: #f0094a;  
    box-shadow:  
            -1px -1px 5px 0px #fff,  
            7px 7px 20px 0px #0003,  
            4px 4px 5px 0px #0002;  
    transition:400ms ease all;  
}  
.btn-5:after{  
    right:inherit;  
    top:inherit;  
    left:0;  
    bottom:0;  
}  
.btn-5:hover:before,  
.btn-5:hover:after{  
    width:100%;  
    transition:800ms ease all;  
}  
  
  
/* 6 */  
.btn-6 {  
    background: rgb(247,150,192);  
    background: radial-gradient(circle, rgba(247,150,192,1) 0%, rgba(118,174,241,1) 100%);  
    line-height: 42px;  
    padding: 0;  
    border: none;  
}  
.btn-6 span {  
    position: relative;  
    display: block;  
    width: 100%;  
    height: 100%;  
}  
.btn-6:before,  
.btn-6:after {  
    position: absolute;  
    content: "";  
    height: 0%;  
    width: 1px;  
    box-shadow:  
            -1px -1px 20px 0px rgba(255,255,255,1),  
            -4px -4px 5px 0px rgba(255,255,255,1),  
            7px 7px 20px 0px rgba(0,0,0,.4),  
            4px 4px 5px 0px rgba(0,0,0,.3);  
}  
.btn-6:before {  
    right: 0;  
    top: 0;  
    transition: all 500ms ease;  
}  
.btn-6:after {  
    left: 0;  
    bottom: 0;  
    transition: all 500ms ease;  
}  
.btn-6:hover{  
    background: transparent;  
    color: #76aef1;  
    box-shadow: none;  
}  
.btn-6:hover:before {  
    transition: all 500ms ease;  
    height: 100%;  
}  
.btn-6:hover:after {  
    transition: all 500ms ease;  
    height: 100%;  
}  
.btn-6 span:before,  
.btn-6 span:after {  
    position: absolute;  
    content: "";  
    box-shadow:  
            -1px -1px 20px 0px rgba(255,255,255,1),  
            -4px -4px 5px 0px rgba(255,255,255,1),  
            7px 7px 20px 0px rgba(0,0,0,.4),  
            4px 4px 5px 0px rgba(0,0,0,.3);  
}  
.btn-6 span:before {  
    left: 0;  
    top: 0;  
    width: 0%;  
    height: .5px;  
    transition: all 500ms ease;  
}  
.btn-6 span:after {  
    right: 0;  
    bottom: 0;  
    width: 0%;  
    height: .5px;  
    transition: all 500ms ease;  
}  
.btn-6 span:hover:before {  
    width: 100%;  
}  
.btn-6 span:hover:after {  
    width: 100%;  
}  
/* 7 */  
.btn-7 {  
    background: linear-gradient(0deg, rgba(255,151,0,1) 0%, rgba(251,75,2,1) 100%);  
    line-height: 42px;  
    padding: 0;  
    border: none;  
}  
.btn-7 span {  
    position: relative;  
    display: block;  
    width: 100%;  
    height: 100%;  
}  
.btn-7:before,  
.btn-7:after {  
    position: absolute;  
    content: "";  
    right: 0;  
    bottom: 0;  
    background: rgba(251,75,2,1);  
    box-shadow:  
            -7px -7px 20px 0px rgba(255,255,255,.9),  
            -4px -4px 5px 0px rgba(255,255,255,.9),  
            7px 7px 20px 0px rgba(0,0,0,.2),  
            4px 4px 5px 0px rgba(0,0,0,.3);  
    transition: all 0.3s ease;  
}  
.btn-7:before{  
    height: 0%;  
    width: 2px;  
}  
.btn-7:after {  
    width: 0%;  
    height: 2px;  
}  
.btn-7:hover{  
    color: rgba(251,75,2,1);  
    background: transparent;  
}  
.btn-7:hover:before {  
    height: 100%;  
}  
.btn-7:hover:after {  
    width: 100%;  
}  
.btn-7 span:before,  
.btn-7 span:after {  
    position: absolute;  
    content: "";  
    left: 0;  
    top: 0;  
    background: rgba(251,75,2,1);  
    box-shadow:  
            -7px -7px 20px 0px rgba(255,255,255,.9),  
            -4px -4px 5px 0px rgba(255,255,255,.9),  
            7px 7px 20px 0px rgba(0,0,0,.2),  
            4px 4px 5px 0px rgba(0,0,0,.3);  
    transition: all 0.3s ease;  
}  
.btn-7 span:before {  
    width: 2px;  
    height: 0%;  
}  
.btn-7 span:after {  
    height: 2px;  
    width: 0%;  
}  
.btn-7 span:hover:before {  
    height: 100%;  
}  
.btn-7 span:hover:after {  
    width: 100%;  
}  
  
/* 8 */  
.btn-8 {  
    background-color: #f0ecfc;  
    background-image: linear-gradient(315deg, #f0ecfc 0%, #c797eb 74%);  
    line-height: 42px;  
    padding: 0;  
    border: none;  
}  
.btn-8 span {  
    position: relative;  
    display: block;  
    width: 100%;  
    height: 100%;  
}  
.btn-8:before,  
.btn-8:after {  
    position: absolute;  
    content: "";  
    right: 0;  
    bottom: 0;  
    background: #c797eb;  
    /*box-shadow: 4px 4px 6px 0 rgba(255,255,255,.5),  
                -4px -4px 6px 0 rgba(116, 125, 136, .2),      inset -4px -4px 6px 0 rgba(255,255,255,.5),      inset 4px 4px 6px 0 rgba(116, 125, 136, .3);*/    transition: all 0.3s ease;  
}  
.btn-8:before{  
    height: 0%;  
    width: 2px;  
}  
.btn-8:after {  
    width: 0%;  
    height: 2px;  
}  
.btn-8:hover:before {  
    height: 100%;  
}  
.btn-8:hover:after {  
    width: 100%;  
}  
.btn-8:hover{  
    background: transparent;  
}  
.btn-8 span:hover{  
    color: #c797eb;  
}  
.btn-8 span:before,  
.btn-8 span:after {  
    position: absolute;  
    content: "";  
    left: 0;  
    top: 0;  
    background: #c797eb;  
    /*box-shadow: 4px 4px 6px 0 rgba(255,255,255,.5),  
                -4px -4px 6px 0 rgba(116, 125, 136, .2),      inset -4px -4px 6px 0 rgba(255,255,255,.5),      inset 4px 4px 6px 0 rgba(116, 125, 136, .3);*/    transition: all 0.3s ease;  
}  
.btn-8 span:before {  
    width: 2px;  
    height: 0%;  
}  
.btn-8 span:after {  
    height: 2px;  
    width: 0%;  
}  
.btn-8 span:hover:before {  
    height: 100%;  
}  
.btn-8 span:hover:after {  
    width: 100%;  
}
  • 9
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

写代码的大学生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值