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

boyanx6个月前技术教程23

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路径动画

相关文章

解锁国内 404 页面:Next.js 设置指南和 33 个有趣 SVG 资源分享

前言当我们访问网站时,如果访问到不存在的路径时,会出现 404 错误。为了避免给访问者带来不良体验,设计网站时通常会在页面上展示“404 页面不存在”的提示,并引导用户进行返回首页等操作。因此在建立网...

交互设计师做好动画后,提交给开发的文档有哪些?

谢邀!简单的说一下自己的看法。首先从制作动画开始。目前制作动画的方式主要有:Gif动画视频动画Web动画,而Web动画又包括:CSS动画、JS动画(Canvas动画、原生JS动画API)、SVG动画等...

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

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

零基础教你学前端——47、SVG绘制路径

在SVG中,使用 path 标签来定义一个路径。它是一个单标签,基本语法为:尖角号 path,斜线尖角号。应用路径,我们可以绘制任意形状的图形。path标签的重要属性 d,用来定义绘制路径的命令,d...

PPT鼠绘知识点概览,又有多少你不知道的方法与技巧?

上周末,利蒙发了一个 PPT 鼠绘的视频,把最近比较火的波吉用 PPT 画了出来:图源公众号:Slidecent看了一会儿比较手痒,于是我在上周末也直播用 PPT 绘制了一幅:没想到,大家对鼠绘还挺感...

【前端必备】Anime.js:用9KB的魔法,让动画“活”起来!

在当今的互联网时代,动画效果已经成为提升用户体验的关键因素之一。如果你还在为复杂的动画效果而烦恼,那么 Anime.js 绝对是你不能错过的选择!什么是 Anime.js?Anime.js 是一款轻量...

发表评论    

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