transform-origin 决定旋转中心,默认为元素中心;设置如 top left 可让元素绕左上角旋转,结合 animation 实现精准动画效果。

在使用 CSS 动画(animation)配合 transform 实现旋转效果时,transform-origin 属性起到关键作用——它决定了元素旋转的中心点。如果不正确设置旋转中心,动画可能看起来偏离预期,比如绕着页面某个角落转而不是自身中心。
transform-origin 用于定义变换(如旋转、缩放、倾斜)的基准点。默认值是 50% 50%,也就是元素的中心。
常见取值方式:
假设你想让一个盒子绕其左上角旋转360度,可以这样写:
立即学习“前端免费学习笔记(深入)”;
<div style="background:#f4f4f4; padding:10px; margin:10px 0; border-radius:4px;">
.keyframe-example {
width: 100px;
height: 100px;
background: #3498db;
animation: rotateAround 2s linear infinite;
transform-origin: top left; /* 关键:设置旋转中心 */
}
<p>@keyframes rotateAround {
from { transform: rotate(0deg); }
to { transform: rotate(360deg); }
}</p></div>这里 transform-origin: top left 明确指定旋转围绕左上角进行。若不设置,元素会默认绕中心旋转。
有时需要在动画过程中或不同状态下切换旋转中心。例如悬停时绕底部旋转:
<div style="background:#f4f4f4; padding:10px; margin:10px 0; border-radius:4px;">
.hover-rotate {
width: 80px;
height: 80px;
background: #e74c3c;
transition: transform-origin 0.3s ease;
}
<p>.hover-rotate:hover {
transform-origin: bottom center;
animation: spin 1s linear infinite;
}</p><p>@keyframes spin {
to { transform: rotate(360deg); }
}</p></div>注意:直接在 hover 上写 transform-origin 可以生效,但若想平滑过渡旋转中心位置,需配合 transition。不过浏览器对 transform-origin 的过渡支持有限,通常只在状态切换时立即生效。
在 3D 动画中,transform-origin 还可指定 Z 轴偏移:
基本上就这些。掌握 transform-origin 就能精准控制动画中元素的旋转行为,避免“乱转”现象。关键是根据设计意图设定合适的原点,再结合 keyframes 实现流畅动画。不复杂但容易忽略。
以上就是css animation与transform-origin旋转中心控制的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号