2

我一直在试图弄清楚如何在滚动时触发反应 css 过渡组。假设我有一堆组件,这个例子在屏幕外渲染:

// 组件.jsx

import React from 'react'
import ReactCSSTransitionGroup from 'react-addons-css-transition-group'
import './style.css'
export default class extends React.Component {
    constructor() {
    super()
    this.state = {
      title: ['an off screen title']}
    }
    render() {
    const displayText = this.state.title.map(i => <h1 key={i}>{i.title}</h1>)
      return (
        <ReactCSSTransitionGroup
            transitionName='atxt'
            transitionEnterTimeout={1000}
            transitionLeaveTimeout={1000}>
          {displayText}
        </ReactCSSTransitionGroup>
      )
    }
}

// 样式.css

.atxt-enter {
  opacity: 0.01;
}
.atxt-enter.atxt-enter-active {
  opacity: 1;
  transition: opacity 1000ms ease-in;
}
.atxt-leave {
  opacity: 1;
}
.atxt-leave.atxt-leave-active {
  opacity: 0.01;
  transition: opacity 1000ms ease-in;
}

我希望在进入视图时触发过渡组,而不仅仅是在最初渲染组件时。我一直在仔细研究文档并探索预制的库/组件来实现这一点,但没有发现任何不涉及引入大型动画库的东西......我知道在我的鸟蛤深处有一种方法可以做到这一点,因此,在这里询问专业人士。你们加油。

4

1 回答 1

6

只是抛出一个想法:

滚动到特定元素时,使用https://github.com/brigade/react-waypoint将组件添加到 DOM。

<Waypoint onEnter={this.handleWaypointEnter} onLeave={this.handleWaypointLeave}/>

在你的handleWaypointEnter,将你的添加<ReactCSSTransitionGroup>...</ReactCSSTransitionGroup>到 dom。这应该可以工作,根据文档,它在进入 dom 时应用动画。

于 2017-03-06T19:01:13.277 回答