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

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

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%;  
}
相关文章
|
13天前
|
前端开发 UED 开发者
有趣的CSS - 文字加载动画效果
这个文本加载动画简单而有趣,可以在网站标题、广告标语或者关键信息的展示上吸引用户的注意力。开发者可以根据需要调整动画的持续时间、步骤数,或者光标颜色等,来适应特定的设计需求。使用这种动态元素,增强网站的互动性和用户体验,同时也为网站增添了一抹活泼的风格。
33 5
|
19天前
|
前端开发 JavaScript
HTML+CSS如何打造撒花动画效果?3分钟学会,炫酷到爆!
HTML+CSS如何打造撒花动画效果?3分钟学会,炫酷到爆!
|
19天前
|
前端开发
CSS动画霓虹灯闪烁效果
CSS动画霓虹灯闪烁效果
|
19天前
|
前端开发 JavaScript
还在为酷炫css动画背景头疼吗?1分钟解决
还在为酷炫css动画背景头疼吗?1分钟解决
|
18天前
|
前端开发 JavaScript 开发者
css过渡与动画
css过渡与动画
31 0
|
前端开发
纯CSS3彩色边线3D立体按钮制作教程
原文:纯CSS3彩色边线3D立体按钮制作教程 今天我们来分享一款利用纯CSS3实现的3D按钮,这款按钮的一个特点是有彩色的边线,这让整个按钮显得比较多姿多彩,没那么枯燥无趣。本文不仅可以让大家看到演示效果,而且我们把制作教程也分享出来,首先来看看效果图: 我们也可以在这里看到这些按钮的DEMO演示。
972 0
|
前端开发
10个实用的 CSS3 按钮效果制作教程
  人们往往喜欢那些有更多互动元素的网站,因此现在很多设计师专注于他们的 CSS3 技能。这是因为 CSS3 技能可以帮助他们在很大的程度上实现所需的吸引力。这里分享的10个优秀的 CSS3 按钮效果制作教程,你可以学习这些技术并使用它们为您的作品创造更多的乐趣。
960 0
|
Web App开发 前端开发 JavaScript
学习制作精美 CSS3 按钮效果的10个优秀教程
  由于互联网世界正在发生变化,人们往往喜欢那些有更多互动元素的网站,因此现在很多 Web 开发人员也在专注于提高他们的 CSS3 技能,因为 CSS3 技能可以帮助他们在很大的程度上实现所需的吸引力。
899 0
|
JavaScript
20个漂亮 CSS3 按钮效果及优秀的制作教程
  在这篇文章中,我们编译了一组有用的 CSS3 动画按钮教程和引人注目的实验。正如我们都知道的,CSS3 在网页设计方面是最重要和最关键的,可以使您的网站对访客更具吸引力和互动性。你可以学习这些教程和试验中的优秀技术并使用它们为您的网站作品创造更多的乐趣。
1082 0
分享40个超棒的CSS3按钮教程
期:2012-10-31  来源:GBin1.com 还记得10个实用的超绚CSS3按钮设计吗?在今天的这篇文章中,我们将带给大家40个精心挑选的CSS3按钮开发教程,相信大家在前面的文章中对CSS3按钮的超酷效果有所了解,希望在今天的这篇文章中,你能够更多的学习如何自己制作漂亮的CSS3按钮...
567 0
下一篇
DDNS