在 SVG 可见时触发 SVG 动画 (SMIL)

Avatar of Chris Coyier
Chris Coyier

DigitalOcean 为您旅程的每个阶段提供云产品。 立即开始使用 200 美元的免费额度!

当需求中出现“可见时”时,你的大脑应该立即想到 IntersectionObserver。 正如 Zach 在这里所做的那样,在元素滚动到视图中时启动动画。

不过,这个动画是一个 SVG SMIL 动画:一个 <animate> 的情况。 SMIL 动画有一些很酷的功能,比如可以在另一个动画结束时开始,这是 CSS 不太容易实现的。 事实证明,SMIL 也有 JavaScript API,因此可以按需启动动画,同时尊重 prefers-reduced-motion

另请查看此内容

.querySelectorAll(`:scope [begin="indefinite"]`);

那个 :scope 东西 对我来说是新的。

直接链接 →