锐英源软件
第一信赖

精通

英语

开源

擅长

开发

培训

胸怀四海 

第一信赖

当前位置:锐英源 / 开源技术 / React / React动画
服务方向
人工智能数据处理
人工智能培训
kaldi数据准备
小语种语音识别
语音识别标注
语音识别系统
语音识别转文字
kaldi开发技术服务
软件开发
运动控制卡上位机
机械加工软件
软件开发培训
Java 安卓移动开发
VC++
C#软件
汇编和破解
驱动开发
联系方式
固话:0371-63888850
手机:138-0381-0136
Q Q:396806883
微信:ryysoft

动画


React为动画提供一个ReactTransitonGroup插件组件作为一个底层的API,一个ReactCSSTransitionGroup来简单地实现基本的CSS动画和过渡。

高级API:ReactCSSTransitionGroup

ReactCSSTransitionGroup是基于ReactTransitionGroup的,在React组件进入或者离开DOM的时候,它是一种简单地执行CSS过渡和动画的方式。

快速开始

ReactCSSTransitionGroup是ReactTransitions的接口。例子中我们让列表项淡入淡出。

var ReactCSSTransitionGroup = React.addons.CSSTransitionGroup;    
var TodoList = React.createClass({    
getInitialState: function() {      
return {items: ['hello', 'world', 'click', 'me']};    
},    
handleAdd: function() {      
var newItems =        
this.state.items.concat([prompt('Enter some text')]);      
this.setState({items: newItems});    
},    
handleRemove: function(i) {      
var newItems = this.state.items;      
newItems.splice(i, 1);      
this.setState({items: newItems});    
},    
render: function() {      
var items = this.state.items.map(function(item, i) {        
return (          
<div key={item} onClick={this.handleRemove.bind(this, i)}>            
{item}          
</div>        
);      
}.bind(this));      
return (        
<div>          
<button onClick={this.handleAdd}>Add Item</button>          
<ReactCSSTransitionGroup transitionName="example">            
{items}          
</ReactCSSTransitionGroup>        
</div>      
);    
}  
});  

一组动画必须要挂载了才能生效

为了能够给它的子级应用过渡效果,ReactCSSTransitionGroup必须已经挂载到了DOM。下面的例子不会生效,因为ReactCSSTransitionGroup被挂载到新项,而不是新项被挂载到ReactCSSTransitionGroup里。将这个与上面的快速开始部分比较一下,看看有什么差异。

  render: function() {      
var items = this.state.items.map(function(item, i) {        
return (          
<div key={item} onClick={this.handleRemove.bind(this, i)}>            
<ReactCSSTransitionGroup transitionName="example">              
{item}            
</ReactCSSTransitionGroup>
</div> 
);
}, this);
return (
<div>          
<button onClick={this.handleAdd}>Add Item</button>    
{items}
</div>
);    
}  

让一项或者零项动起来

虽然在上面的例子中,我们渲染了一个项目列表到ReactCSSTransitionGroup里,ReactCSSTransitionGroup的子级可以是一个或零个项目。这使它能够让一个元素实现进入和离开的动画。同样,你可以通过移动一个新的元素来替换当前元素。随着新元素的移入,当前元素移出。例如,我们可以由此实现一个简单的图片轮播器:

var ReactCSSTransitionGroup = React.addons.CSSTransitionGroup;    
var ImageCarousel = React.createClass({    
propTypes: {      
imageSrc: React.PropTypes.string.isRequired    
},    
render: function() {      
return (        
<div>          
<ReactCSSTransitionGroup transitionName="carousel">            
<img src={this.props.imageSrc} key={this.props.imageSrc} />          
</ReactCSSTransitionGroup>        
</div>      
);    
}  
});  

禁用动画

如果你想,你可以禁用入场或者出场动画。例如,有些时候,你可能想要一个入场动画,不要出场动画,但是ReactCSSTransitionGroup会在移除DOM节点之前等待一个动画完成。你可以给ReactCSSTransitionGroup添加transitionEnter={false}或者transitionLeave={false} props来禁用这些动画。

注意:

当使用ReactCSSTransitionGroup的时候,没有办法通知你在过渡效果结束或者在执行动画的时候做一些复杂的运算。如果你想要更多细粒度的控制,你可以使用底层的ReactTransitionGroup API,该API提供了你自定义过渡效果所需要的函数。

底层的API:ReactTransitionGroup

ReactTransitionGroup是动画的基础。它可以通过React.addons.TransitionGroup得到。当子级被添加或者从其中移除(就像上面的例子)的时候,特殊的生命周期函数就会在它们上面被调用。

componentWillEnter(callback)

在组件被添加到已有的TransitionGroup中的时候,该函数和componentDidMount()被同时调用。这将会阻塞其它动画触发,直到callback被调用。该函数不会在TransitionGroup初始化渲染的时候调用。

componentDidEnter()

该函数在传给componentWillEnter的callback函数被调用之后调用。

componentWillLeave(callback)

该函数在子级从ReactTransitionGroup中移除的时候调用。虽然子级被移除了,ReactTransitionGroup将会使它继续在DOM中,直到callback被调用。

componentDidLeave()

该函数在willLeave callback被调用的时候调用(与componentWillUnmount是同一时间)。

友情链接
版权所有 Copyright(c)2004-2021 锐英源软件
公司注册号:410105000449586 豫ICP备08007559号 最佳分辨率 1024*768
地址:郑州大学北校区院(文化路97号院)内