ant-design/components/drawer/demo/multi-level-drawer.md

111 lines
2.2 KiB
Markdown
Raw Normal View History

2018-06-30 12:32:55 +08:00
---
order: 5
title:
zh-CN: 多层抽屉
en-US: Multi-level drawer
---
## zh-CN
在抽屉内打开新的抽屉,用以解决多分支任务的复杂状况。
## en-US
Open a new drawer on top of an existing drawer to handle multi branch tasks
```jsx
import { Drawer, Button } from 'antd';
2018-06-30 12:32:55 +08:00
class App extends React.Component {
2018-06-30 12:32:55 +08:00
state = { visible: false, childrenDrawer: false };
2018-07-04 08:29:42 +08:00
2018-06-30 12:32:55 +08:00
showDrawer = () => {
this.setState({
visible: true,
});
};
2018-07-04 08:29:42 +08:00
2018-06-30 12:32:55 +08:00
onClose = () => {
this.setState({
visible: false,
});
};
2018-07-04 08:29:42 +08:00
2018-06-30 12:32:55 +08:00
showChildrenDrawer = () => {
this.setState({
childrenDrawer: true,
});
};
2018-07-04 08:29:42 +08:00
2018-06-30 12:32:55 +08:00
onChildrenDrawerClose = () => {
this.setState({
childrenDrawer: false,
});
};
2018-07-04 08:29:42 +08:00
2018-06-30 12:32:55 +08:00
render() {
return (
<div>
<Button type="primary" onClick={this.showDrawer}>
Open drawer
2018-06-30 12:32:55 +08:00
</Button>
<Drawer
title="Multi-level drawer"
2018-06-30 12:32:55 +08:00
width={520}
closable={false}
onClose={this.onClose}
visible={this.state.visible}
push={this.state.childrenDrawer}
2018-06-30 12:32:55 +08:00
>
<Button type="primary" onClick={this.showChildrenDrawer}>
Two-level drawer
</Button>
2018-06-30 12:32:55 +08:00
<Drawer
title="Food"
width={320}
closable={false}
onClose={this.onChildrenDrawerClose}
visible={this.state.childrenDrawer}
>
This is two-level drawer
2018-06-30 12:32:55 +08:00
</Drawer>
<div
style={{
position: 'absolute',
bottom: 0,
width: '100%',
borderTop: '1px solid #e8e8e8',
padding: '10px 16px',
textAlign: 'right',
left: 0,
background: '#fff',
borderRadius: '0 0 4px 4px',
}}
>
<Button
style={{
marginRight: 8,
}}
onClick={this.onClose}
>
Cancel
</Button>
<Button onClick={this.onClose} type="primary">
Submit
</Button>
</div>
</Drawer>
</div>
);
}
}
2018-07-02 12:27:06 +08:00
ReactDOM.render(<App />, mountNode);
2018-06-30 12:32:55 +08:00
```
<style>
#_hj_feedback_container{
display:none
}
</style>