mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-18 03:14:07 +08:00
1719748a29
* chore: eslint add consistent-type-imports * fix avatar * Update Item.tsx
122 lines
3.9 KiB
Markdown
122 lines
3.9 KiB
Markdown
---
|
||
order: 3
|
||
iframe: 360
|
||
title:
|
||
zh-CN: 侧边布局
|
||
en-US: Sider
|
||
---
|
||
|
||
## zh-CN
|
||
|
||
侧边两列式布局。页面横向空间有限时,侧边导航可收起。
|
||
|
||
侧边导航在页面布局上采用的是左右的结构,一般主导航放置于页面的左侧固定位置,辅助菜单放置于工作区顶部。内容根据浏览器终端进行自适应,能提高横向空间的使用率,但是整个页面排版不稳定。侧边导航的模式层级扩展性强,一、二、三级导航项目可以更为顺畅且具关联性的被展示,同时侧边导航可以固定,使得用户在操作和浏览中可以快速的定位和切换当前位置,有很高的操作效率。但这类导航横向页面内容的空间会被牺牲一部分。
|
||
|
||
> 🛎️ 想要 3 分钟实现?试试 [ProLayout](https://procomponents.ant.design/components/layout)!
|
||
|
||
## en-US
|
||
|
||
Two-columns layout. The sider menu can be collapsed when horizontal space is limited.
|
||
|
||
Generally, the mainnav is placed on the left side of the page, and the secondary menu is placed on the top of the working area. Contents will adapt the layout to the viewing area to improve the horizontal space usage, while the layout of the whole page is not stable.
|
||
|
||
The level of the aside navigation is scalable. The first, second, and third level navigations could be present more fluently and relevantly, and aside navigation can be fixed, allowing the user to quickly switch and spot the current position, improving the user experience. However, this navigation occupies some horizontal space of the contents.
|
||
|
||
```tsx
|
||
import type { MenuProps } from 'antd';
|
||
import { Layout, Menu, Breadcrumb } from 'antd';
|
||
import {
|
||
DesktopOutlined,
|
||
PieChartOutlined,
|
||
FileOutlined,
|
||
TeamOutlined,
|
||
UserOutlined,
|
||
} from '@ant-design/icons';
|
||
|
||
const { Header, Content, Footer, Sider } = Layout;
|
||
|
||
type MenuItem = Required<MenuProps>['items'][number];
|
||
|
||
function getItem(
|
||
label: React.ReactNode,
|
||
key: React.Key,
|
||
icon?: React.ReactNode,
|
||
children?: MenuItem[],
|
||
): MenuItem {
|
||
return {
|
||
key,
|
||
icon,
|
||
children,
|
||
label,
|
||
} as MenuItem;
|
||
}
|
||
|
||
const items: MenuItem[] = [
|
||
getItem('Option 1', '1', <PieChartOutlined />),
|
||
getItem('Option 2', '2', <DesktopOutlined />),
|
||
getItem('User', 'sub1', <UserOutlined />, [
|
||
getItem('Tom', '3'),
|
||
getItem('Bill', '4'),
|
||
getItem('Alex', '5'),
|
||
]),
|
||
getItem('Team', 'sub2', <TeamOutlined />, [getItem('Team 1', '6'), getItem('Team 2', '8')]),
|
||
getItem('Files', '9', <FileOutlined />),
|
||
];
|
||
|
||
class SiderDemo extends React.Component {
|
||
state = {
|
||
collapsed: false,
|
||
};
|
||
|
||
onCollapse = (collapsed: boolean) => {
|
||
console.log(collapsed);
|
||
this.setState({ collapsed });
|
||
};
|
||
|
||
render() {
|
||
const { collapsed } = this.state;
|
||
return (
|
||
<Layout style={{ minHeight: '100vh' }}>
|
||
<Sider collapsible collapsed={collapsed} onCollapse={this.onCollapse}>
|
||
<div className="logo" />
|
||
<Menu theme="dark" defaultSelectedKeys={['1']} mode="inline" items={items} />
|
||
</Sider>
|
||
<Layout className="site-layout">
|
||
<Header className="site-layout-background" style={{ padding: 0 }} />
|
||
<Content style={{ margin: '0 16px' }}>
|
||
<Breadcrumb style={{ margin: '16px 0' }}>
|
||
<Breadcrumb.Item>User</Breadcrumb.Item>
|
||
<Breadcrumb.Item>Bill</Breadcrumb.Item>
|
||
</Breadcrumb>
|
||
<div className="site-layout-background" style={{ padding: 24, minHeight: 360 }}>
|
||
Bill is a cat.
|
||
</div>
|
||
</Content>
|
||
<Footer style={{ textAlign: 'center' }}>Ant Design ©2018 Created by Ant UED</Footer>
|
||
</Layout>
|
||
</Layout>
|
||
);
|
||
}
|
||
}
|
||
|
||
export default () => <SiderDemo />;
|
||
```
|
||
|
||
```css
|
||
#components-layout-demo-side .logo {
|
||
height: 32px;
|
||
margin: 16px;
|
||
background: rgba(255, 255, 255, 0.3);
|
||
}
|
||
|
||
.site-layout .site-layout-background {
|
||
background: #fff;
|
||
}
|
||
```
|
||
|
||
<style>
|
||
[data-theme="dark"] .site-layout .site-layout-background {
|
||
background: #141414;
|
||
}
|
||
</style>
|