最稳妥方式是用 lottie-web 加载 JSON 动画:引入官方库、指定容器、调用 loadAnimation();需确保 JSON 路径正确、容器存在且有尺寸、AE 导出选 JSON 格式并轮廓化文字。
直接用 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() 的关键参数避坑点参数写错会导致白屏、报错或动画不动,常见问题集中在路径、容器和跨域上。
path 必须是相对或绝对 URL,不能是本地文件路径(如 file:/// 协议下会触发 CORS 错误)container 必须是真实 DOM 元素,且在调用前已存在;若在 DOMContentLoaded 外执行,建议加 document.getElementById() 判空loop 和 autoplay 默认为 false,不显式设为 true 就不会动Access-Control-Allow-Origin,否则控制台报 “Failed to fetch”拿到 animationItem 实例后,所有交互逻辑都靠它。别再用 setTimeout 模拟播放——lottie-web 提供了精确帧控 API。
const anim = lottie.loadAnimation({ ... });
anim.play();暂停:anim.pause()
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 错或 404div 若无宽高(如 height: auto 且子元素为空),SVG 渲染器可能无法绘制——给容器设 width 和 height(支持 vh/vmax 等响应式单位){,不是 (说明服务器返回了 404 HTML 页面而非 JSON)
Include in project” 但没嵌入字体?Web 字体未加载会导致文字图层空白——导出时尽量用轮廓化文字(Convert fonts to shapes)真正麻烦的是 AE 动画里用了不被 Lottie 支持的特性(比如 3D 图层、部分表达式、第三方插件效果),这种只能回 AE 修改,没有运行时补救办法。