如何为 SVG 路径设置独立旋转速度并固定旋转中心点

发布时间 - 2025-12-30 00:00:00    点击率:

本文介绍如何使用 svg 原生 `` 实现多个路径围绕同一中心点(如 `80 80`)以不同持续时间独立旋转,无需 javascript,兼容性好且语义清晰。

在 SVG 动画中,若需让多个 元素围绕同一固定中心点(例如画布几何中心)以不同速度旋转,最简洁、高效且符合 Web 标准的方式是:为每个路径所在的 容器(或直接为 )添加独立的 元素,并统一指定 from 和 to 的旋转中心坐标。

关键要点如下:

  • 旋转中心必须显式声明:from="0 cx cy" 和 to="360 cx cy" 中的 cx cy 是绝对坐标(相对于 SVG 根元素的 viewBox),决定了所有旋转的锚点。本例中 80 80 对应 viewBox="0 0 160 160" 的中心,确保路径绕画布中心转动。
  • 速度由 dur 属性独立控制:path1 设置 dur="1.00s" 实现每秒一转;path2 设置 dur="3.00s" 则三秒一转——两者互不干扰。
  • 动画绑定在容器 上更合理:将 直接置于 内部,使整个组(含路径)统一变换,语义清晰且避免路径自身坐标系干扰。

以下是可直接运行的完整示例代码:


  
  
    
    
  

  
  
    
    
  

⚠️ 注意事项与最佳实践

  • 确保 viewBox 尺寸与 from/to 中的中心坐标匹配(如 viewBox="0 0 160 160" → 中心为 80 80);
  • 不要将 放在 根层级,否则会作用于整个 SVG,失去路径级控制;
  • 若需延迟启动某条路径(如 path2 在 path1 开始后 0.5 秒再动),可修改 begin="0.5s";
  • 所有现代浏览器均原生支持该语法(Chrome/Firefox/Safari/Edge),无需 polyfill;
  • 如需更复杂交互动画(如点击暂停、变速),建议配合 SMIL 的 begin="click" 或迁移到 CSS @keyframes + transform-origin(但需注意路径需转为 display: block 并包裹在定位容器中)。

通过此方法,你可在零 JS 依赖下,精准、轻量、可维护地实现多路径差异化 SVG 旋转动画。


# css  # javascript  # java  # js  # svg  # 浏览器  # edge  # safari 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: HTML5打空格有哪些误区_新手常犯的空格使用错误【技巧】  如何做网站制作流程,*游戏网站怎么搭建?  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  HTML透明颜色代码在Angular里怎么设置_Angular透明颜色使用指南【详解】  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  如何在宝塔面板中创建新站点?  Laravel如何构建RESTful API_Laravel标准化API接口开发指南  C语言设计一个闪闪的圣诞树  nodejs redis 发布订阅机制封装实现方法及实例代码  网页设计与网站制作内容,怎样注册网站?  Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析  Laravel DB事务怎么使用_Laravel数据库事务回滚操作  Laravel如何实现URL美化Slug功能_Laravel使用eloquent-sluggable生成别名【方法】  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  如何在企业微信快速生成手机电脑官网?  公司网站制作价格怎么算,公司办个官网需要多少钱?  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】  javascript基本数据类型及类型检测常用方法小结  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  如何登录建站主机?访问步骤全解析  音响网站制作视频教程,隆霸音响官方网站?  Python文件操作最佳实践_稳定性说明【指导】  Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康  如何在宝塔面板中修改默认建站目录?  php485函数参数是什么意思_php485各参数详细说明【介绍】  简历没回改:利用AI润色让你的文字更专业  JS弹性运动实现方法分析  Android仿QQ列表左滑删除操作  如何用美橙互联一键搭建多站合一网站?  详解Android图表 MPAndroidChart折线图  EditPlus中的正则表达式实战(5)  新三国志曹操传主线渭水交兵攻略  Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】  Laravel Sail是什么_基于Docker的Laravel本地开发环境Sail入门  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  laravel怎么实现图片的压缩和裁剪_laravel图片压缩与裁剪方法  Laravel如何安装Breeze扩展包_Laravel用户注册登录功能快速实现【流程】  创业网站制作流程,创业网站可靠吗?  如何在Windows 2008云服务器安全搭建网站?  利用python获取某年中每个月的第一天和最后一天  HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】  Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】  如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?  Laravel如何获取当前登录用户信息_Laravel Auth门面使用与Session用户读取【技巧】  独立制作一个网站多少钱,建立网站需要花多少钱?  如何在阿里云域名上完成建站全流程?  php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】  Laravel如何创建自定义Facades?(详细步骤)  JS碰撞运动实现方法详解