【发布时间】:2019-01-17 16:44:49
【问题描述】:
我在 ReactJS 和 GatsbyJS (V2) 项目中使用 react-transition-group。
我的页面过渡使用动画,但是当Link 退出时,exiting 动画被缩短,因为下一页已准备好进入。
我已尝试延迟 Link 操作,但当页面更改延迟时,exit 动画不会触发,直到 delay 结束并且 Link 被操作。
如何在启动exiting 动画onClick 的同时更改页面delay?或者,有没有更好的方法或props 可用?
这是我的代码
Layout.js
class Layout extends React.Component {
...
return (
<Transition>{children}</Transition>
);
}
Transition.js
class Transition extends React.Component {
constructor(props) {
super(props);
this.state = { exiting: false };
this.listenerHandler = this.listenerHandler.bind(this);
}
listenerHandler() {
this.setState({ exiting: true });
}
componentDidMount() {
window.addEventListener(historyExitingEventType, this.listenerHandler);
}
componentWillUnmount() {
window.removeEventListener(historyExitingEventType, this.listenerHandler);
}
static getDerivedStateFromProps({ exiting }) {
if (exiting) {
return { exiting: false };
}
return null;
}
render() {
const transitionProps = {
timeout: {
enter: 0,
exit: timeout
},
appear: true,
in: !this.state.exiting
};
return (
<ReactTransition {...transitionProps}>
{status => (
<div
style={{
...getTransitionStyle({ status, timeout })
}}
>
{this.props.children}
</div>
)}
</ReactTransition>
);
}
}
export default Transition;
gatsby-config.js
import createHistory from 'history/createBrowserHistory';
const timeout = 1500;
const historyExitingEventType = `history::exiting`;
const getUserConfirmation = (pathname, callback) => {
const event = new CustomEvent(historyExitingEventType, {
detail: { pathname }
});
window.dispatchEvent(event);
setTimeout(() => {
callback(true);
}, timeout);
};
let history;
if (typeof document !== 'undefined') {
history = createHistory({ getUserConfirmation });
history.block(location => location.pathname);
}
export const replaceHistory = () => history;
export { historyExitingEventType, timeout };
getTransitionStyle.js
const getTransitionStyles = timeout => {
return {
entering: {
transform: `scale(1.05) translateZ(0)`,
opacity: 0
},
entered: {
transition: `transform 750ms ease, opacity ${timeout}ms ease`,
transitionDelay: `750ms`,
transform: `scale(1) translateZ(0)`,
opacity: 1
},
exiting: {
transition: `transform 750ms ease, opacity ${timeout}ms ease`,
transform: `scale(0.98) translateZ(0)`,
opacity: 0
}
};
};
const getTransitionStyle = ({ timeout, status }) =>
getTransitionStyles(timeout)[status];
export default getTransitionStyle;
【问题讨论】:
-
如果您使用的是最新的 Gatsby 测试版,这将不起作用,因为 Gatsby 现在使用的是 Reach Router 而不是 react-router。 (尚)不支持延迟路由转换。我对此here发表了评论。
-
谢谢@FabianSchultz。我昨天在提供的链接上看到了您的评论,并将寻找对该主题的回应。再次感谢您 - 很高兴知道 Gatsby 社区中的某个人正在寻找解决方案。
-
@FabianSchultz。我注意到您在 Gatsby github 上添加了一个完美解决我的问题的解决方案。谢谢你。我想如果你想用那个解决方案来回答这个问题并关闭它,我会按照你的方式发送赏金。干杯。
标签: javascript reactjs gatsby react-transition-group