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%;  
}
相关文章
|
4天前
|
JavaScript 前端开发
jQuery和CSS3滑动展开菜单按钮插件
这是一款jQuery和CSS3滑动展开菜单按钮插件。该滑动展开菜单按钮在用户点击主菜单按钮之后,子菜单以滑动的方式依次展开
39 21
|
27天前
纯css3实现的百分比渐变进度条加载动画源码
纯css3实现的百分比渐变进度条加载动画特效源码
53 31
|
12天前
|
Web App开发 移动开发 JavaScript
纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码
这是一款基于纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码。画面中左下角是一个圆锥形礼炮卡通效果,呈现出节日庆祝时礼花爆破、五彩纸屑纷飞的动画特效。整体动画效果采用纯css3+svg实现,没有引入任何外部图形或js脚本元素。建议使用支持HTML5与css3效果较好的火狐(Firefox)或谷歌(Chrome)等浏览器预览本源码。
30 6
|
22天前
|
前端开发 JavaScript UED
CSS滚动效果和视差滚动的原理、应用及其对用户体验的影响。从平滑滚动到元素跟随,再到滚动触发动画
本文探讨了CSS滚动效果和视差滚动的原理、应用及其对用户体验的影响。从平滑滚动到元素跟随,再到滚动触发动画,这些效果增强了页面的吸引力和互动性。视差滚动通过不同层次元素的差异化移动,增加了页面的深度感和沉浸感。文章还讨论了实现方法、性能优化及案例分析,旨在为设计师和开发者提供实用指导。
50 7
|
24天前
CSS3实现的九宫格图片鼠标悬停去除遮罩层源码
CSS3实现的九宫格图片鼠标悬停去除遮罩层源码
17 0
CSS3实现的九宫格图片鼠标悬停去除遮罩层源码
|
27天前
纯css3加载loading发光变色动画代码
纯css3加载loading发光变色动画特效代码是一款基于css3 keyframes属性实现的发光变色圆点串联旋转loading加载动画
22 2
|
22天前
|
前端开发 测试技术 定位技术
如何利用HTML和CSS构建企业级网站的全过程。从项目概述到页面结构设计,再到HTML结构搭建与CSS样式设计,最后实现具体页面并进行优化提升,全面覆盖了网站开发的关键步骤
本文深入介绍了如何利用HTML和CSS构建企业级网站的全过程。从项目概述到页面结构设计,再到HTML结构搭建与CSS样式设计,最后实现具体页面并进行优化提升,全面覆盖了网站开发的关键步骤。通过实例展示了主页、关于我们、产品展示、新闻动态及联系我们等页面的设计与实现,强调了合理布局、美观设计及用户体验的重要性。旨在为企业打造一个既专业又具吸引力的线上平台。
46 7
|
22天前
|
前端开发 JavaScript 搜索推荐
HTML与CSS在Web组件化中的核心作用及前端技术趋势
本文探讨了HTML与CSS在Web组件化中的核心作用及前端技术趋势。从结构定义、语义化到样式封装与布局控制,两者不仅提升了代码复用率和可维护性,还通过响应式设计、动态样式等技术增强了用户体验。面对兼容性、代码复杂度等挑战,文章提出了相应的解决策略,强调了持续创新的重要性,旨在构建高效、灵活的Web应用。
31 6