mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-13 16:48:08 +08:00
104 lines
2.2 KiB
Markdown
104 lines
2.2 KiB
Markdown
---
|
|
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';
|
|
|
|
class App extends React.Component {
|
|
state = { visible: false, childrenDrawer: false };
|
|
|
|
showDrawer = () => {
|
|
this.setState({
|
|
visible: true,
|
|
});
|
|
};
|
|
|
|
onClose = () => {
|
|
this.setState({
|
|
visible: false,
|
|
});
|
|
};
|
|
|
|
showChildrenDrawer = () => {
|
|
this.setState({
|
|
childrenDrawer: true,
|
|
});
|
|
};
|
|
|
|
onChildrenDrawerClose = () => {
|
|
this.setState({
|
|
childrenDrawer: false,
|
|
});
|
|
};
|
|
|
|
render() {
|
|
return (
|
|
<div>
|
|
<Button type="primary" onClick={this.showDrawer}>
|
|
Open drawer
|
|
</Button>
|
|
<Drawer
|
|
title="Multi-level drawer"
|
|
width={520}
|
|
closable={false}
|
|
onClose={this.onClose}
|
|
visible={this.state.visible}
|
|
>
|
|
<Button type="primary" onClick={this.showChildrenDrawer}>
|
|
Two-level drawer
|
|
</Button>
|
|
<Drawer
|
|
title="Two-level Drawer"
|
|
width={320}
|
|
closable={false}
|
|
onClose={this.onChildrenDrawerClose}
|
|
visible={this.state.childrenDrawer}
|
|
>
|
|
This is two-level drawer
|
|
</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>
|
|
);
|
|
}
|
|
}
|
|
|
|
ReactDOM.render(<App />, mountNode);
|
|
```
|