mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-04 08:59:40 +08:00
68 lines
1.5 KiB
Markdown
68 lines
1.5 KiB
Markdown
---
|
|
order: 5
|
|
title: 添加与删除
|
|
---
|
|
|
|
场景里有增加或删除条目时也会触发动画。
|
|
|
|
````jsx
|
|
import { QueueAnim, Button } from 'antd';
|
|
|
|
const Test = React.createClass({
|
|
getInitialState() {
|
|
return {
|
|
show: true,
|
|
items: [
|
|
<li key="0"></li>,
|
|
<li key="1"></li>,
|
|
<li key="2"></li>,
|
|
],
|
|
};
|
|
},
|
|
onClick() {
|
|
this.setState({
|
|
show: !this.state.show,
|
|
});
|
|
},
|
|
onAdd() {
|
|
let items = this.state.items;
|
|
items.push(<li key={Date.now()}></li>);
|
|
this.setState({
|
|
show: true,
|
|
items,
|
|
});
|
|
},
|
|
onRemove() {
|
|
let items = this.state.items;
|
|
items.splice(items.length - 1, 1);
|
|
this.setState({
|
|
show: true,
|
|
items,
|
|
});
|
|
},
|
|
render() {
|
|
return (
|
|
<div>
|
|
<p className="buttons">
|
|
<Button type="primary" onClick={this.onClick}>切换</Button>
|
|
<Button onClick={this.onAdd} style={{ marginLeft: 10 }}>添加</Button>
|
|
<Button onClick={this.onRemove} style={{ marginLeft: 10 }}>删除</Button>
|
|
</p>
|
|
<div className="demo-content">
|
|
<div className="demo-listBox" key="b">
|
|
<div className="demo-list">
|
|
<div className="title"></div>
|
|
<QueueAnim component="ul" type={['right', 'left']}>
|
|
{this.state.show ? this.state.items : null}
|
|
</QueueAnim>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
},
|
|
});
|
|
|
|
ReactDOM.render(<Test />, mountNode);
|
|
````
|