mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-08 20:38:39 +08:00
0a70563e44
* 🎬 improve drawer demo * 🎬 fix drawer demo glitch close #24011
86 lines
1.6 KiB
Markdown
86 lines
1.6 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 (
|
|
<>
|
|
<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>
|
|
</Drawer>
|
|
</>
|
|
);
|
|
}
|
|
}
|
|
|
|
ReactDOM.render(<App />, mountNode);
|
|
```
|
|
|
|
<style>
|
|
[data-theme="dark"] .site-multi-level-drawer-footer {
|
|
border-top: 1px solid #303030;
|
|
background: #1f1f1f;
|
|
}
|
|
</style>
|