首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >不使用InertiaJs的Framer移动和退出属性

不使用InertiaJs的Framer移动和退出属性
EN

Stack Overflow用户
提问于 2022-05-20 17:07:38
回答 1查看 179关注 0票数 2

我想知道如何使用“退出”属性与框架运动和InertiaJs /ReactJ请。

目前我有两页:

profil.js

代码语言:javascript
复制
const { pathname } = window.location
...

<div>
    <motion.div className="flex flex-col" layoutId={`title-3`}
            initial={{opacity: 0}}
            animate={{
                y: [-20, 0],
                opacity: [0, 1]
            }}
            exit={{scale: 2}}
            key={{pathname}}
            transition={{duration: 0.2, ease: "easeOut", delay: 0.1}}
>
    <span>Profil</span>
    </motion.div>
</div>

home.js

代码语言:javascript
复制
const { pathname } = window.location
...

<div>
    <motion.div className="flex flex-col" layoutId={`title-3`}
            initial={{opacity: 0}}
            animate={{
                y: [-20, 0],
                opacity: [0, 1]
            }}
            exit={{scale: 2}}
            key={{pathname}}
            transition={{duration: 0.2, ease: "easeOut", delay: 0.1}}
>
    <span>Home</span>
    </motion.div>
</div>

我在我的应用程序(app.js)上设置了app.js:

代码语言:javascript
复制
import { AnimateSharedLayout } from 'framer-motion';

return render(
    <Provider store={store}>
        <AnimateSharedLayout>
            <App {...props} />
        </AnimateSharedLayout>
    </Provider>, el
);

当我点击侧边栏中的"home“或"profil”时,我看到了动画,但没有看到退出动画。

我用的是InertiaJ和ReactJ。

你知道为什么我看不到出口吗?

EN

回答 1

Stack Overflow用户

发布于 2022-05-20 17:17:51

一旦您单击"home“或"profile",该元素就会立即从DOM中删除,因此它在那里的时间不会足够长,无法看到动画。

框架运动文档

通过使用AnimatePresence包装运动组件,它们获得了exit属性的使用,该属性可以定义一组值或要在移除之前对其进行动画处理的变体名称。

尝试用这样的<motion.div>包装<AnimatePresence>

代码语言:javascript
复制
const { pathname } = window.location
...

<div>
    <AnimatePresence>
    <motion.div className="flex flex-col" layoutId={`title-3`}
            initial={{opacity: 0}}
            animate={{
                y: [-20, 0],
                opacity: [0, 1]
            }}
            exit={{scale: 2}}
            key={{pathname}}
            transition={{duration: 0.2, ease: "easeOut", delay: 0.1}}
    >
    <span>Home</span>
    </motion.div>
    </AnimatePresence>
</div>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72322506

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档