2016-12-30 21:41:28 +08:00
|
|
|
---
|
|
|
|
order: 3
|
|
|
|
title:
|
|
|
|
zh-CN: 侧边布局
|
|
|
|
en-US: Sider
|
|
|
|
---
|
|
|
|
|
|
|
|
## zh-CN
|
|
|
|
|
|
|
|
多用在两列式布局。
|
|
|
|
|
|
|
|
## en-US
|
|
|
|
|
|
|
|
Be used in the two-columns layout.
|
|
|
|
|
2017-02-13 10:55:53 +08:00
|
|
|
````jsx
|
2016-12-30 21:41:28 +08:00
|
|
|
import { Layout, Menu, Breadcrumb, Icon } from 'antd';
|
|
|
|
const { Header, Content, Footer, Sider } = Layout;
|
2017-02-17 11:12:52 +08:00
|
|
|
const SubMenu = Menu.SubMenu;
|
2016-12-30 21:41:28 +08:00
|
|
|
|
|
|
|
class SiderDemo extends React.Component {
|
|
|
|
state = {
|
|
|
|
collapsed: false,
|
2017-02-17 11:12:52 +08:00
|
|
|
mode: 'inline',
|
2016-12-30 21:41:28 +08:00
|
|
|
};
|
|
|
|
onCollapse = (collapsed) => {
|
|
|
|
console.log(collapsed);
|
2017-02-17 11:12:52 +08:00
|
|
|
this.setState({
|
|
|
|
collapsed,
|
|
|
|
mode: collapsed ? 'vertical' : 'inline',
|
|
|
|
});
|
2016-12-30 21:41:28 +08:00
|
|
|
}
|
|
|
|
render() {
|
|
|
|
return (
|
|
|
|
<Layout>
|
|
|
|
<Sider
|
|
|
|
collapsible
|
|
|
|
collapsed={this.state.collapsed}
|
|
|
|
onCollapse={this.onCollapse}
|
|
|
|
>
|
|
|
|
<div className="logo" />
|
2017-02-17 11:12:52 +08:00
|
|
|
<Menu theme="dark" mode={this.state.mode} defaultSelectedKeys={['6']}>
|
|
|
|
<SubMenu
|
|
|
|
key="sub1"
|
|
|
|
title={<span><Icon type="user" /><span className="nav-text">User</span></span>}
|
|
|
|
>
|
|
|
|
<Menu.Item key="1">Tom</Menu.Item>
|
|
|
|
<Menu.Item key="2">Bill</Menu.Item>
|
|
|
|
<Menu.Item key="3">Alex</Menu.Item>
|
|
|
|
</SubMenu>
|
|
|
|
<SubMenu
|
|
|
|
key="sub2"
|
|
|
|
title={<span><Icon type="team" /><span className="nav-text">Team</span></span>}
|
|
|
|
>
|
|
|
|
<Menu.Item key="4">Team 1</Menu.Item>
|
|
|
|
<Menu.Item key="5">Team 2</Menu.Item>
|
|
|
|
</SubMenu>
|
2016-12-30 21:41:28 +08:00
|
|
|
<Menu.Item key="6">
|
2017-02-17 11:12:52 +08:00
|
|
|
<span>
|
|
|
|
<Icon type="file" />
|
|
|
|
<span className="nav-text">File</span>
|
|
|
|
</span>
|
2016-12-30 21:41:28 +08:00
|
|
|
</Menu.Item>
|
|
|
|
</Menu>
|
|
|
|
</Sider>
|
|
|
|
<Layout>
|
|
|
|
<Header style={{ background: '#fff', padding: 0 }} />
|
|
|
|
<Content style={{ margin: '0 16px' }}>
|
|
|
|
<Breadcrumb style={{ margin: '12px 0' }}>
|
2017-02-17 11:12:52 +08:00
|
|
|
<Breadcrumb.Item>User</Breadcrumb.Item>
|
|
|
|
<Breadcrumb.Item>Bill</Breadcrumb.Item>
|
2016-12-30 21:41:28 +08:00
|
|
|
</Breadcrumb>
|
|
|
|
<div style={{ padding: 24, background: '#fff', minHeight: 360 }}>
|
2017-02-17 11:12:52 +08:00
|
|
|
Bill is a cat.
|
2016-12-30 21:41:28 +08:00
|
|
|
</div>
|
|
|
|
</Content>
|
|
|
|
<Footer style={{ textAlign: 'center' }}>
|
|
|
|
Ant Design ©2016 Created by Ant UED
|
|
|
|
</Footer>
|
|
|
|
</Layout>
|
|
|
|
</Layout>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ReactDOM.render(<SiderDemo />, mountNode);
|
|
|
|
````
|
|
|
|
|
|
|
|
````css
|
|
|
|
#components-layout-demo-side .logo {
|
|
|
|
height: 32px;
|
|
|
|
background: #333;
|
|
|
|
border-radius: 6px;
|
|
|
|
margin: 16px;
|
|
|
|
}
|
|
|
|
|
|
|
|
#components-layout-demo-side .ant-layout-sider-collapsed .anticon {
|
2017-01-11 11:32:17 +08:00
|
|
|
font-size: 16px;
|
2017-02-24 18:04:16 +08:00
|
|
|
margin-left: 8px;
|
2016-12-30 21:41:28 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#components-layout-demo-side .ant-layout-sider-collapsed .nav-text {
|
2017-01-11 11:32:17 +08:00
|
|
|
display: none;
|
2016-12-30 21:41:28 +08:00
|
|
|
}
|
2017-02-17 11:12:52 +08:00
|
|
|
|
|
|
|
#components-layout-demo-side .ant-layout-sider-collapsed .ant-menu-submenu-vertical > .ant-menu-submenu-title:after {
|
|
|
|
display: none;
|
2017-02-24 18:04:16 +08:00
|
|
|
}
|
2016-12-30 21:41:28 +08:00
|
|
|
````
|