gpt4 book ai didi

javascript - 当元素处于 View 中时(当您滚动到元素时)成帧器运动动画

转载 作者:行者123 更新时间:2023-11-28 03:22:52 25 4
gpt4 key购买 nike

是否有任何内置方法可以使动画在元素处于 View 中时开始(例如,当我们滚动到元素时)?

Framer Motion有安装动画部分,内容如下:

When a component mounts, it'll automatically animate to the values in animate if they're different from those defined in style or initial

所以我真的找不到一种直接的方法来让动画在进入 View 时开始。

但是,我现在看到的唯一选项是使用 Animation Controls这意味着我必须手动在滚动上实现监听器并触发 control.start(),任何更简单的方法都非常感谢。

最佳答案

framer-motion 自版本 5.3 以来已内置对此用例的支持。

这是一个演示该模式的 CodeSandbox:https://codesandbox.io/s/framer-motion-animate-in-view-5-3-94j13

相关代码:

function FadeInWhenVisible({ children }) {
return (
<motion.div
initial="hidden"
whileInView="visible"
viewport={{ once: true }}
transition={{ duration: 0.3 }}
variants={{
visible: { opacity: 1, scale: 1 },
hidden: { opacity: 0, scale: 0 }
}}
>
{children}
</motion.div>
);
}

用法:

<FadeInWhenVisible>
<Box />
</FadeInWhenVisible>

以前的版本:

您当前可以使用imperative animation controls来达到这个效果。相交观察器对于检测元素当前是否可见非常有用。

这是一个演示该模式的 CodeSandbox:https://codesandbox.io/s/framer-motion-animate-in-view-gqcc8 .

相关代码:

function FadeInWhenVisible({ children }) {
const controls = useAnimation();
const [ref, inView] = useInView();

useEffect(() => {
if (inView) {
controls.start("visible");
}
}, [controls, inView]);

return (
<motion.div
ref={ref}
animate={controls}
initial="hidden"
transition={{ duration: 0.3 }}
variants={{
visible: { opacity: 1, scale: 1 },
hidden: { opacity: 0, scale: 0 }
}}
>
{children}
</motion.div>
);
}

关于javascript - 当元素处于 View 中时(当您滚动到元素时)成帧器运动动画,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58958972/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com