在CSS开发中,transition属性可以让我们在元素样式发生变化时,以平滑的过渡效果呈现,非常适合用来制作按钮悬停动画。通过给按钮设置初始样式,再结合hover伪类定义悬停时的样式,最后添加transition属性控制过渡的时长和效果,就能实现各类交互感十足的按钮动画。

transition属性基础介绍
transition是CSS3新增的过渡属性,它可以在元素样式值发生改变时,让变化过程从旧值平滑过渡到新值,而不是瞬间完成。它的常用子属性如下:
- transition-property:指定需要应用过渡效果的CSS属性,比如width、background-color等,设置为all表示所有可过渡属性都生效
- transition-duration:指定过渡效果的持续时间,单位为秒s或者毫秒ms,比如0.3s表示过渡时长为0.3秒
- transition-timing-function:指定过渡的速度曲线,常用值有ease(默认,慢快慢)、linear(匀速)、ease-in(慢开始)、ease-out(慢结束)等
- transition-delay:指定过渡效果开始的延迟时间,默认是0s,一般不需要设置
实际开发中我们通常会使用简写形式,格式为transition: property duration timing-function delay;,后两个参数可以省略,使用默认值。
基础按钮悬停动画实现
我们先来实现一个最基础的按钮悬停颜色渐变效果,按钮默认是蓝色背景,悬停时背景变为深蓝色,文字颜色从白色变为浅黄色,过渡时长0.3秒。
/* 按钮基础样式 */
.btn {
padding: 12px 24px;
background-color: #2196F3;
color: #ffffff;
border: none;
border-radius: 4px;
font-size: 16px;
cursor: pointer;
/* 设置过渡效果:所有可过渡属性,0.3秒,慢快慢曲线 */
transition: all 0.3s ease;
}
/* 悬停时的样式 */
.btn:hover {
background-color: #0b7dda;
color: #fffacd;
}
对应的HTML结构如下:
<button class="btn">基础悬停按钮</button>
多属性组合的悬停动画
我们可以同时对多个属性设置过渡效果,比如让按钮在悬停时不仅改变颜色,还产生位移、阴影变化,让动画更有层次感。
.multi-effect-btn {
padding: 12px 24px;
background-color: #4CAF50;
color: white;
border: none;
border-radius: 4px;
font-size: 16px;
cursor: pointer;
/* 分别设置不同属性的过渡效果,也可以统一用all */
transition: background-color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
}
.multi-effect-btn:hover {
background-color: #45a049;
/* 向上移动2像素 */
transform: translateY(-2px);
/* 添加阴影效果 */
box-shadow: 0 4px 8px rgba(0,0,0,0.2);
}
HTML结构:
<button class="multi-effect-btn">多效果悬停按钮</button>
尺寸变化的悬停动画
除了颜色和位移,我们还可以让按钮在悬停时改变尺寸,比如放大或者缩小,这里演示悬停时按钮宽度和字体放大的效果。
.size-change-btn {
padding: 12px 24px;
background-color: #ff9800;
color: white;
border: none;
border-radius: 4px;
font-size: 16px;
cursor: pointer;
width: 120px;
transition: width 0.3s ease, font-size 0.3s ease;
}
.size-change-btn:hover {
width: 140px;
font-size: 18px;
}
HTML结构:
<button class="size-change-btn">尺寸变化按钮</button>
注意事项
- 不是所有CSS属性都支持transition过渡,比如display属性就不支持,需要切换显示隐藏时可以用opacity配合visibility实现
- 过渡时长不要设置过长,一般0.2s到0.5s之间比较合适,过长会让用户觉得响应迟缓
- 如果只需要对部分属性做过渡,建议明确指定transition-property,而不是用all,性能会更好
- transform相关的变换属性(平移、旋转、缩放等)默认都支持过渡,而且性能优于直接修改宽高、位置等属性
CSStransition按钮悬停动画hover伪类修改时间:2026-06-13 09:18:13