Anime.js轻量级、高性能的 JavaScript 动画库

boyanx5天前技术教程3

Anime.js(发音为 /'aen..me/)是一款轻量级、高性能的 JavaScript 动画库,专注于通过简洁 API 实现流畅的网页动画效果。以下是其核心特性和使用指南:


一、核心特性与优势

  1. 多场景支持
    可操作 CSS 属性、SVG 路径、DOM 属性及 JavaScript 对象,支持从基础元素移动(如平移、旋转)到复杂 SVG 路径动画。例如,通过 translateX 和 rotate 实现元素位移与旋转联动。
  2. 轻量高效
    文件体积仅约 20KB(压缩后),内置硬件加速优化,即使在低性能设备上也能保持流畅运行。例如,通过 easing: 'easeInOutQuad' 实现平滑的缓动效果。
  3. 灵活的时间控制
    提供时间轴(Timeline)功能,支持动画的串联、并行及延迟控制。例如,通过 anime.timeline() 实现多个动画按顺序或重叠播放。
  4. 跨浏览器兼容
    支持 Chrome 24+、Safari 8+、Firefox 32+ 等主流浏览器,自动处理供应商前缀(如 -webkit-)。
  5. 丰富的插件生态
    可结合 ScrollMagic 实现滚动触发动画,或与 Three.js 集成创建 3D 交互动画。

二、快速入门指南

安装与引入

  • CDN 引入(推荐新手):
  • html
  • 运行
  • 复制
  • <script src="https://cdnjs.cloudflare.com/ajax/libs/animejs/3.2.1/anime.min.js"></script>
  • npm 安装(适合项目开发):
  • bash
  • 复制
  • npm install animejs --save
  • 引入模块:import anime from 'animejs/lib/anime.es.js';

基础动画示例

javascript

复制

// 使元素向右移动 250px,旋转 360 度,背景变白
anime({
  targets: '.box',
  translateX: 250,
  rotate: '1turn',
  backgroundColor: '#FFF',
  duration: 800,
  easing: 'easeInOutQuad',
  loop: true
});

说明:targets 指定动画对象(支持 CSS 选择器或 DOM 元素),duration 控制时长(毫秒),loop 设置循环播放

进阶功能

  1. 交错动画(Staggering)
    通过 delay: anime.stagger(100) 实现元素组的错序动画效果,适用于列表项或卡片布。
  2. SVG 路径动画
    动态修改 SVG 的 d 属性,实现路径绘制效果:
  3. javascript
  4. 复制
  5. anime({ targets: svgPath, d: 'M10 80 C 40 10, 65 10, 95 80', duration: 2000, easing: 'easeInOutQuad' });
  6. 提示:使用 anime.path() 可让元素沿 SVG 路径运动。
  7. 时间轴控制
    创建复杂动画序列:
  8. javascript
  9. 复制
  10. const timeline = anime.timeline({ easing: 'easeOutExpo', duration: 750 }); timeline .add({ targets: '.box1', translateX: 250 }) .add({ targets: '.box2', translateY: 50 }, '-=600'); // 与前一个动画重叠 600ms

四、适用场景

  • 网页过渡效果:页面滚动、菜单展开等交互设计
  • 数据可视化:动态图表、数据增长动画
  • 游戏开发:角色动作、场景切换(如太阳系行星运动模拟)。
  • 品牌展示:LOGO 动态效果、产品演示动画

标签: svg路径动画

相关文章

【HarmonyOS Next之旅】兼容JS的类Web开发(五) -> Svg

目录1 -> 基础知识1.1 -> 创建Svg组件1.2 -> 设置属性2 -> 绘制图形3 -> 绘制路径4 -> 绘制文本4.1 -> 文本4.2 -&g...

学下SVG矢量图形,你也是个小小艺术家!

SVG 全面教程1. SVG 简介SVG(Scalable Vector Graphics)是一种基于XML的矢量图形格式,可以在不损失质量的情况下任意缩放。2. 基础语法<svg width=...

手把手教你H5实现工厂游戏的CSS动画效果「实践」

作者:吴冠禧 WecTeam转发连接:https://mp.weixin.qq.com/s/u5GHsA0vHz8A_MmGslRw2g0 契机与背景今年Q1(2020年第一季度)参与了京喜事业部「京...

移动前端重构实战系列:5-7章

(本文系来自腾讯imweb团队 结一大大 关于移动端重构经验以及思想的实战系列,推荐点击左下角的阅读原文。)”本系列教程为实战教程,是自己移动端重构经验及思想的一次总结,也是对sheral UI的一次...

2.3 文件格式全解:PSD/JPG/PNG/SVG/GIF

2.3 文件格式全解:PSD/JPG/PNG/SVG/GIF一、文件格式的核心意义文件格式是数字图像的存储规则,决定了:- 信息保留程度(图层/透明度/动画)- 压缩方式与画质损失- 跨平台兼容性-...

时间轴动画怎么加才惊艳?简单,腾讯御用PPT设计师直接爆料

大家应该收集或者见过很多不错的时间轴的页面设计吧?时间轴算是PPT制作中经常遇到的页面类型,个人述职、项目路演、企业介绍等等,都会用到时间轴来让用户更加直观地了解个人或公司。比如腾讯的时间轴页:又比如...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。