如何为 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


相关推荐: 制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?  PHP 500报错的快速解决方法  Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】  高防服务器租用指南:配置选择与快速部署攻略  如何在万网利用已有域名快速建站?  JavaScript如何实现类型判断_typeof和instanceof有什么区别  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  微信h5制作网站有哪些,免费微信H5页面制作工具?  Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门  Firefox Developer Edition开发者版本入口  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  详解Android图表 MPAndroidChart折线图  如何在腾讯云服务器上快速搭建个人网站?  Laravel如何实现密码重置功能_Laravel密码找回与重置流程  Python图片处理进阶教程_Pillow滤镜与图像增强  Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】  HTML 中动态设置元素 name 属性的正确语法详解  公司门户网站制作流程,华为官网怎么做?  手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  java中使用zxing批量生成二维码立牌  如何在万网ECS上快速搭建专属网站?  无锡营销型网站制作公司,无锡网选车牌流程?  Laravel如何实现事件和监听器?(Event & Listener实战)  Mybatis 中的insertOrUpdate操作  如何在云服务器上快速搭建个人网站?  详解MySQL数据库的安装与密码配置  香港服务器选型指南:免备案配置与高效建站方案解析  打开php文件提示内存不足_怎么调整php内存限制【解决方案】  Laravel Seeder怎么填充数据_Laravel数据库填充器的使用方法与技巧  如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框  Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性  Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理  JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)  利用 Google AI 进行 YouTube 视频 SEO 描述优化  Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】  如何在阿里云香港服务器快速搭建网站?  如何在云指建站中生成FTP站点?  php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  香港服务器网站卡顿?如何解决网络延迟与负载问题?  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  如何快速生成凡客建站的专业级图册?  Laravel全局作用域是什么_Laravel Eloquent Global Scopes应用指南  Laravel怎么实现支付功能_Laravel集成支付宝微信支付  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  EditPlus中的正则表达式 实战(4)  Android利用动画实现背景逐渐变暗  Laravel Docker环境搭建教程_Laravel Sail使用指南