ant-design/components/enter-animation/demo/enter-data.md

95 lines
2.6 KiB
Markdown
Raw Normal View History

2015-09-09 15:05:06 +08:00
# 指定节点动画进出场
2015-07-28 18:33:40 +08:00
- order: 1
2015-09-07 18:37:07 +08:00
通过加上 `enter-data` 属性来指定需要动画进场的元素,并且可以定义每个元素的动画效果。
2015-07-28 18:33:40 +08:00
2015-08-04 17:07:31 +08:00
2015-07-28 18:33:40 +08:00
---
````jsx
var EnterAnimation = antd.EnterAnimation;
var Test = React.createClass({
2015-08-12 14:57:45 +08:00
getInitialState(){
return {
2015-09-07 18:37:07 +08:00
enter:{
type:'right',
interval:.1,
},
leave:{
interval:0.03
},
bool:true
2015-08-12 14:57:45 +08:00
}
},
2015-09-07 18:37:07 +08:00
onClick(){
2015-08-12 14:57:45 +08:00
this.setState({
2015-09-07 18:37:07 +08:00
bool:!this.state.bool
2015-08-12 14:57:45 +08:00
})
},
2015-07-28 18:33:40 +08:00
render() {
return (
2015-08-12 14:57:45 +08:00
<div>
2015-08-24 18:06:47 +08:00
<div style={{marginBottom:20}}>
2015-09-07 18:37:07 +08:00
<button className="ant-btn ant-btn-primary" onClick={this.onClick}>切换</button>
2015-08-12 14:57:45 +08:00
</div>
2015-09-07 18:37:07 +08:00
<EnterAnimation enter={this.state.enter} leave={this.state.leave}>
{this.state.bool ? <div key='enter-data'>
2015-07-28 18:33:40 +08:00
<div className="demo-header" enter-data={{type: 'alpha'}}>
<div className="logo" enter-data={{type: 'left'}}>
<img width="30" src="https://t.alipayobjects.com/images/rmsweb/T1B9hfXcdvXXXXXXXX.svg"/>
<span>logo</span>
</div>
<ul>
<li enter-data></li>
<li enter-data></li>
<li enter-data></li>
<li enter-data></li>
<li enter-data></li>
</ul>
</div>
<div className="demo-content">
<div className="demo-title" enter-data={{type:'alpha'}}>我是标题</div>
<div className="demo-kp">
<ul>
<li enter-data></li>
<li enter-data></li>
<li enter-data></li>
</ul>
</div>
2015-09-08 18:22:30 +08:00
<div className="demo-title" enter-data={{type:'alpha',queueId:1,delay:0.8}} leave-data={{delay:0.1}}>我是标题</div>
2015-07-28 18:33:40 +08:00
<div className="demo-listBox">
2015-07-29 12:17:18 +08:00
<div className="demo-list">
<div className="title" enter-data={{type:'bottom',queueId:1}}></div>
<ul>
<li enter-data={{type:'bottom',queueId:1}}></li>
<li enter-data={{type:'bottom',queueId:1}}></li>
<li enter-data={{type:'bottom',queueId:1}}></li>
<li enter-data={{type:'bottom',queueId:1}}></li>
<li enter-data={{type:'bottom',queueId:1}}></li>
</ul>
</div>
2015-07-28 18:33:40 +08:00
</div>
</div>
<div className="demo-footer" enter-data={{type:'bottom',queueId:1}}></div>
2015-09-07 18:37:07 +08:00
</div> : null}
2015-07-28 18:33:40 +08:00
</EnterAnimation>
2015-08-12 14:57:45 +08:00
</div>
2015-07-28 18:33:40 +08:00
)
}
});
React.render(<Test />
, document.getElementById('components-enter-animation-demo-enter-data'));
````
<style>
#components-enter-animation-demo-enter-data {
width: 600px;
text-align: center;
overflow: hidden;
margin: 20px auto;
}
</style>