首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >框架-运动,动画时延迟rotateY

框架-运动,动画时延迟rotateY
EN

Stack Overflow用户
提问于 2020-03-24 05:04:30
回答 2查看 6.1K关注 0票数 4

我正在使用Framer,我试图找到一种方法来延迟rotateY的动画,而x动画到一个特定的位置,然后启动rotateY。

这在Framer议案中有可能吗?

示例:

代码语言:javascript
复制
const variants = {
  flip: {
    rotateY: 0,
    x: -20,
    scale: 1,
    transition: {
      ease: "easeInOut",
      duration: 1.2
    }
  },
  hidden: {
    rotateY: 180,
    x: 150,
    scale: 0.5,
    transition: {
      ease: "easeInOut",
      duration: 1
    }
  }
};
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-03-31 11:13:16

您可以为每个属性配置一个转换。这使您可以向rotateY添加必要的延迟。

代码语言:javascript
复制
const duration = 1.2;

const variants = {
  flip: {
    rotateY: 0,
    x: -20,
    scale: 1,
    transition: {
      ease: "easeInOut",
      duration,
      rotateY: {
        delay: duration,
        duration
      }
    }
  },
  hidden: {
    rotateY: 180,
    x: 150,
    scale: 0.5,
    transition: {
      ease: "easeInOut",
      duration,
      rotateY: {
        delay: duration,
        duration
      }
    }
  }
};

看这个CodeSandbox

票数 6
EN

Stack Overflow用户

发布于 2020-09-02 17:44:21

@amann上面的帖子在2020年9月对我来说没有意义

我必须在过渡期间更新所有相关属性,以确保它们连续运行:

代码语言:javascript
复制
transition: {
      x: {
        ease: "easeInOut",
        duration: duration
      },
      rotateY: {
        duration: duration,
        delay: duration
      }
    }

完整的例子:

代码语言:javascript
复制
import * as React from "react";
import { motion } from "framer-motion";
import styled from "styled-components";

const duration = 1.2;

const variants = {
  flip: {
    rotateY: 180,
    x: 150,
    transition: {
      x: {
        ease: "easeInOut",
        duration: duration
      },
      rotateY: {
        duration: duration,
        delay: duration
      }
    }
  },
  hidden: {
    rotateY: 0,
    x: -20,
    transition: {
      x: {
        ease: "easeInOut",
        duration: duration
      },
      rotateY: {
        duration: duration,
        delay: duration
      }
    }
  }
};

const Box = styled(motion.div)`
  background: white;
  border-radius: 30px;
  width: 150px;
  height: 150px;
`;

export const Example = (props) => {
  return (
    <motion.div 
      initial={false}
      animate={props.toggle ? "flip": "hidden"}
    >
      <Box variants={variants} />
    </motion.div>
  )
}

码箱演示

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60825253

复制
相关文章

相似问题

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