0

0

如何用Lottie制作HTML5动画_Lottie动画集成方法【轻量教程】

星夢妙者

星夢妙者

发布时间:2026-01-06 18:25:13

|

129人浏览过

|

来源于php中文网

原创

最稳妥方式是用 lottie-web 加载 JSON 动画:引入官方库、指定容器、调用 loadAnimation();需确保 JSON 路径正确、容器存在且有尺寸、AE 导出选 JSON 格式并轮廓化文字。

如何用lottie制作html5动画_lottie动画集成方法【轻量教程】

直接用 lottie-web 加载 JSON 动画文件是最稳妥的方式,Lottie 官方已放弃对旧版 bodymovin 渲染器的维护,所有新项目请绕开 jQuery 插件或过时的 CDN 链接。

如何用 lottie-web 在 HTML 中加载动画

核心是引入官方库 + 指定容器 + 调用 lottie.loadAnimation()。不依赖构建工具也能跑,适合静态页快速集成。

  • 确保动画导出为 JSON 格式(AE 用 Lottie 插件导出时选 “JSON” 而非 “HTML”)
  • 在页面中放一个空容器,比如
  • 通过 或传统 引入 lottie-web;推荐用 ESM 方式避免全局污染:
import lottie from 'https://unpkg.com/lottie-web@2.12.4/build/player/lottie_light.min.js';

lottie.loadAnimation({
  container: document.getElementById('lottie-container'),
  renderer: 'svg',
  loop: true,
  autoplay: true,
  path: './animation.json'
});

注意:renderer: 'svg' 兼容性好、缩放清晰;若需高性能复杂动画可换 'canvas',但 iOS Safari 对 canvas 渲染的某些滤镜支持有限。

lottie.loadAnimation() 的关键参数避坑点

参数写错会导致白屏、报错或动画不动,常见问题集中在路径、容器和跨域上。

立即学习前端免费学习笔记(深入)”;

GPTAgent
GPTAgent

一个无代码创建AI应用程序的工具

下载
  • path 必须是相对或绝对 URL,不能是本地文件路径(如 file:/// 协议下会触发 CORS 错误)
  • container 必须是真实 DOM 元素,且在调用前已存在;若在 DOMContentLoaded 外执行,建议加 document.getElementById() 判空
  • loopautoplay 默认为 false,不显式设为 true 就不会动
  • 若 JSON 文件放在不同域名下,需服务端配 Access-Control-Allow-Origin,否则控制台报 “Failed to fetch

如何控制播放、暂停、跳转到指定帧

拿到 animationItem 实例后,所有交互逻辑都靠它。别再用 setTimeout 模拟播放——lottie-web 提供了精确帧控 API。

  • 保存返回值:const anim = lottie.loadAnimation({ ... });
  • 播放:anim.play();暂停:anim.pause()
  • 跳转到第 30 帧(假设总帧数 ≥ 30):anim.goToAndStop(30, true);第三个参数 true 表示不播放,仅定位
  • 获取当前帧:anim.currentFrame;获取总帧数:anim.totalFrames
  • 监听完成事件:anim.addEventListener('complete', () => { ... })

注意:goToAndPlay() 会从指定帧开始播放,但若动画已暂停,它不会自动恢复播放状态——得手动跟一句 anim.play()

为什么动画不显示?几个高频原因

90% 的“白屏”问题不是代码写错,而是环境或资源链路断了。

  • 检查浏览器控制台:出现 “Cannot find module 'lottie-web'” 是路径/CDN 失效;出现 “Failed to load resource” 是 path 错或 404
  • 检查容器尺寸:div 若无宽高(如 height: auto 且子元素为空),SVG 渲染器可能无法绘制——给容器设 widthheight(支持 vh/vmax 等响应式单位)
  • 检查 JSON 内容:用文本编辑器打开,确认首字符是 {,不是 (说明服务器返回了 404 HTML 页面而非 JSON)
  • AE 导出时勾选了 “Include in project” 但没嵌入字体?Web 字体未加载会导致文字图层空白——导出时尽量用轮廓化文字(Convert fonts to shapes)

真正麻烦的是 AE 动画里用了不被 Lottie 支持的特性(比如 3D 图层、部分表达式、第三方插件效果),这种只能回 AE 修改,没有运行时补救办法。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

406

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

531

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

html5动画制作有哪些制作方法
html5动画制作有哪些制作方法

html5动画制作方法有使用CSS3动画、使用JavaScript动画库、使用HTML5 Canvas等。想了解更多html5动画制作方法相关内容,可以阅读本专题下面的文章。

500

2023.10.23

HTML与HTML5的区别
HTML与HTML5的区别

HTML与HTML5的区别:1、html5支持矢量图形,html本身不支持;2、html5中可临时存储数据,html不行;3、html5新增了许多控件;4、html本身不支持音频和视频,html5支持;5、html无法处理不准确的语法,html5能够处理等等。想了解更多HTML与HTML5的相关内容,可以阅读本专题下面的文章。

422

2024.03.06

html5从入门到精通汇总
html5从入门到精通汇总

想系统掌握HTML5开发?本合集精选全网优质学习资源,涵盖免费教程、实战项目、视频课程与权威电子书,从基础语法到高级特性(Canvas、本地存储、响应式布局等)一应俱全,适合零基础小白到进阶开发者,助你高效入门并精通HTML5前端开发。

11

2025.12.30

html5新老标签汇总
html5新老标签汇总

HTML5在2026年持续优化网页语义化与交互体验,不仅引入了如<header>、<nav>、<article>、<section>、<aside>、<footer>等结构化标签,还新增了<video>、<audio>、<canvas>、<figure>、<time>、<mark>等增强多媒体与

12

2025.12.30

java学习网站推荐汇总
java学习网站推荐汇总

本专题整合了java学习网站相关内容,阅读专题下面的文章了解更多详细内容。

6

2026.01.08

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
jQuery 教程
jQuery 教程

共42课时 | 3.9万人学习

HTML+CSS基础与实战
HTML+CSS基础与实战

共132课时 | 9.4万人学习

tp6+adminlte搭建通用后台
tp6+adminlte搭建通用后台

共39课时 | 5.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号