【问题标题】:Toggle slide fade out, slide fade (back) in with CSS Keyframes and React使用 CSS 关键帧和 React 切换幻灯片淡出、幻灯片淡入(后退)
【发布时间】:2022-02-02 13:29:10
【问题描述】:

我有一个框 (div),我想用滑出动画切换它,然后在按下按钮时滑回动画(完全相反)。

我不希望在初始页面呈现时出现任何动画。我能够在按下按钮时成功地将框向左滑动/淡出页面,但是向后滑动没有任何过渡或动画。

如何在元素返回视图时添加此过渡而不添加将在初始页面渲染时触发的类?

SlideBoxApp.js

class SlideBoxApp extends React.Component {
  constructor(props) {
    super(props)
    this.state = {
        slideIn: false
    }
  }
  
  toggleSlide() {
    const { slideIn } = this.state
    this.setState({slideIn: !slideIn})
  }
  
  render() {
    const { slideIn } = this.state
      return (
        <div>
         <button onClick={() => this.toggleSlide()}>slide in</button>
         <div className={`box ${slideIn? 'slideLeft' : ''}`}></div>
        </div>
      )
   }
}

ReactDOM.render(<SlideBoxApp />, document.querySelector("#app"))

SlideBoxApp.css

body {
  background: #20262E;
  padding: 20px;
  font-family: Helvetica;
}

button {
  margin-bottom: 10px;
}

#app {
  background: #fff;
  border-radius: 4px;
  padding: 20px;
  transition: all 0.2s;
}

.box {
  width: 100px;
  height: 100px;
  background-color: pink;
}

.slideLeft {
  animation-duration: 500ms;
  animation-name: slideLeft;
  animation-fill-mode: forwards;
}

.slideRight {
  animation-duration: 500ms;
  animation-name: slideLeft;
  animation-fill-mode: forwards;
}

@keyframes slideLeft {
    0% {
        transform: translate(0, 0);
        opacity: 1;
    }

    100% {
        transform: translate(-100%, 0);
        opacity: 0;
    }
}

@keyframes slideRight {
    0% {
        transform: translate(0, 0);
        opacity: 0;
    }

    100% {
        transform: translate(100%, 0);
        opacity: 1;
    }
}

JS Fiddle Link Here

【问题讨论】:

标签: javascript css reactjs css-animations


【解决方案1】:

返回的幻灯片没有任何过渡或动画

我已经搜索了一种解决方案,可以在删除 keyframe 后将元素动画化回其原始状态,但找不到。
拥有keyframe 意味着在 startend 状态之间的动画,因此如果您想同时为 in 设置动画,初始页面动画是不可避免的em>out

但是,您可以只使用 transition 而不是 keyframes 来实现您想要的结果。
只需在.slideLeft 类中添加新状态:

.slideLeft {
  transform: translate(-100%, 0);
  opacity: 0;
}

并给.box 一些transition 属性:

.box {
  transition-duration: .5s;
  transition-property: transform, opacity;
}

我更新了你的JS Fiddle

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2010-11-24
    • 1970-01-01
    • 1970-01-01
    • 2017-12-26
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-07-07
    相关资源
    最近更新 更多