使用CSS transition与transform结合可实现旋转、缩放和位移动画。通过设置transition控制动画速度曲线,配合rotate()、scale()、translate()等函数,在悬停时触发平滑视觉效果,如.box:hover实现45度旋转,.zoom:hover放大1.5倍,.slide:hover位移20px×10px,.combo:hover综合旋转30度、放大1.2倍并位移15px,提升交互体验。

使用CSS过渡(transition)与Transform结合,可以轻松实现元素的旋转、缩放和位移动画效果。这种组合无需JavaScript,仅通过CSS即可创建流畅的视觉交互。
基础概念:Transition 与 Transform
Transition 控制属性变化的速度曲线,定义动画的持续时间、缓动方式和延迟。它让属性改变不再是瞬间完成,而是平滑过渡。
Transform 用于对元素进行旋转、缩放、倾斜和平移等变形操作。常见函数包括 rotate()、scale()、translate() 和 skew()。
实现旋转动画
将元素在悬停时顺时针旋转45度:
立即学习“前端免费学习笔记(深入)”;
- 设置 transition 监听 transform 属性
- 初始状态 rotate(0deg),触发时变为 rotate(45deg)
示例代码:
.box {
width: 100px;
height: 100px;
background: #3498db;
transition: transform 0.3s ease;
}
.box:hover {
transform: rotate(45deg);
}
实现缩放动画
鼠标悬停时放大1.5倍,常用于按钮或图片增强交互感:
- 使用 scale() 函数调整尺寸比例
- 配合 transform-origin 可控制缩放中心点
示例代码:
.zoom {
transition: transform 0.4s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.zoom:hover {
transform: scale(1.5);
}
实现位移动画
让元素在触发时横向或纵向移动,适合菜单滑出、提示弹窗等场景:
- translateX() 水平移动,translateY() 垂直移动
- 可组合使用 translate(x, y)
示例:向右平移20px并下移10px
.slide {
transition: transform 0.5s ease-out;
}
.slide:hover {
transform: translate(20px, 10px);
}
综合应用:旋转+缩放+位移
三种变换可同时作用于一个元素,创造更丰富的动效:
- transition 仍只需监听 transform 一次
- transform 属性中按顺序写多个函数
示例:悬停时旋转、放大并位移
.combo {
width: 80px;
height: 80px;
background: #e67e22;
transition: transform 0.6s ease-in-out;
}
.combo:hover {
transform: translate(15px, 15px) rotate(30deg) scale(1.2);
}
基本上就这些。合理搭配 transition 的时间与贝塞尔曲线,再结合 transform 的多种函数,就能做出自然流畅的动画效果,提升页面交互体验。注意避免过度使用,保持动画服务于用户体验。










