我正在尝试让一个组件在React中有条件地呈现,并在它呈现时滑动它
包:
"react": "^16.8.6",
"react-transition-group": "^4.0.1",代码片段:
{ expanded && (
<CSSTransition in={expanded} timeout={500} classNames="slide">
<div className="expandedDiv"></div>
</CSSTransition>
)}css:
.slide-enter {
transform: translateX(-100%);
transition: .3s linear;
}
.slide-enter-active {
transform: translateX(0%);
}
.slide-exit {
transform: translateX(0%);
transition: .3s linear;
}
.slide-exit-active {
transform: translateX(-100%);
}结构:
+------------------------------+
| | | header |
| | |____________+
| | | content |
| | | |
| | | |
| nav | expanded | |
| | | |
| | | |
| | | |
+------------------------------+Expanded应该在true上滑入,在false上滑出,它是代码片段中的expandedDiv
div只是弹出,没有动画。预期行为是从左到右的线性过渡
谢谢
发布于 2019-05-27 18:38:03
<CSSTransition
in={expanded}
timeout={300}
classNames="slide"
unmountOnExit
onEnter={() => this.toggleExpanded(true)}
onExited={() => this.toggleExpanded(false)}
>
<div className="expandedDiv">
</div>
</CSSTransition>
</div>发布于 2019-05-25 03:29:42
我需要多看一点你的代码,才能准确地理解你想要做什么。但是如果我没弄错的话,试着这样做:
<CSSTransition
in={expanded}
appear={true}
key = {this.props.location.key}
timeout={500}
classNames="slide">
<div className='expandedDiv'> </div>
</CSSTransition>https://stackoverflow.com/questions/56298258
复制相似问题