mirror of
https://gitee.com/ant-design/ant-design.git
synced 2024-12-16 01:41:02 +08:00
775d1800bb
* chore(deps-dev): bump eslint-config-prettier from 6.15.0 to 7.0.0 Bumps [eslint-config-prettier](https://github.com/prettier/eslint-config-prettier) from 6.15.0 to 7.0.0. - [Release notes](https://github.com/prettier/eslint-config-prettier/releases) - [Changelog](https://github.com/prettier/eslint-config-prettier/blob/main/CHANGELOG.md) - [Commits](https://github.com/prettier/eslint-config-prettier/compare/v6.15.0...v7.0.0) Signed-off-by: dependabot[bot] <support@github.com> * chore: fix eslint style * chore: prettier code style Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: afc163 <afc163@gmail.com>
194 lines
4.2 KiB
Markdown
194 lines
4.2 KiB
Markdown
---
|
|
order: 4
|
|
title:
|
|
zh-CN: 组合示例
|
|
en-US: Complete example
|
|
---
|
|
|
|
## zh-CN
|
|
|
|
使用了 PageHeader 提供的所有能力。
|
|
|
|
## en-US
|
|
|
|
Show all props provided by PageHeader.
|
|
|
|
```jsx
|
|
import { PageHeader, Menu, Dropdown, Button, Tag, Typography, Row } from 'antd';
|
|
import { EllipsisOutlined } from '@ant-design/icons';
|
|
|
|
const { Paragraph } = Typography;
|
|
|
|
const menu = (
|
|
<Menu>
|
|
<Menu.Item>
|
|
<a target="_blank" rel="noopener noreferrer" href="http://www.alipay.com/">
|
|
1st menu item
|
|
</a>
|
|
</Menu.Item>
|
|
<Menu.Item>
|
|
<a target="_blank" rel="noopener noreferrer" href="http://www.taobao.com/">
|
|
2nd menu item
|
|
</a>
|
|
</Menu.Item>
|
|
<Menu.Item>
|
|
<a target="_blank" rel="noopener noreferrer" href="http://www.tmall.com/">
|
|
3rd menu item
|
|
</a>
|
|
</Menu.Item>
|
|
</Menu>
|
|
);
|
|
|
|
const DropdownMenu = () => (
|
|
<Dropdown key="more" overlay={menu}>
|
|
<Button
|
|
style={{
|
|
border: 'none',
|
|
padding: 0,
|
|
}}
|
|
>
|
|
<EllipsisOutlined
|
|
style={{
|
|
fontSize: 20,
|
|
verticalAlign: 'top',
|
|
}}
|
|
/>
|
|
</Button>
|
|
</Dropdown>
|
|
);
|
|
|
|
const routes = [
|
|
{
|
|
path: 'index',
|
|
breadcrumbName: 'First-level Menu',
|
|
},
|
|
{
|
|
path: 'first',
|
|
breadcrumbName: 'Second-level Menu',
|
|
},
|
|
{
|
|
path: 'second',
|
|
breadcrumbName: 'Third-level Menu',
|
|
},
|
|
];
|
|
|
|
const IconLink = ({ src, text }) => (
|
|
<a className="example-link">
|
|
<img className="example-link-icon" src={src} alt={text} />
|
|
{text}
|
|
</a>
|
|
);
|
|
|
|
const content = (
|
|
<>
|
|
<Paragraph>
|
|
Ant Design interprets the color system into two levels: a system-level color system and a
|
|
product-level color system.
|
|
</Paragraph>
|
|
<Paragraph>
|
|
Ant Design's design team preferred to design with the HSB color model, which makes it
|
|
easier for designers to have a clear psychological expectation of color when adjusting colors,
|
|
as well as facilitate communication in teams.
|
|
</Paragraph>
|
|
<div>
|
|
<IconLink
|
|
src="https://gw.alipayobjects.com/zos/rmsportal/MjEImQtenlyueSmVEfUD.svg"
|
|
text="Quick Start"
|
|
/>
|
|
<IconLink
|
|
src="https://gw.alipayobjects.com/zos/rmsportal/NbuDUAuBlIApFuDvWiND.svg"
|
|
text=" Product Info"
|
|
/>
|
|
<IconLink
|
|
src="https://gw.alipayobjects.com/zos/rmsportal/ohOEPSYdDTNnyMbGuyLb.svg"
|
|
text="Product Doc"
|
|
/>
|
|
</div>
|
|
</>
|
|
);
|
|
|
|
const Content = ({ children, extraContent }) => (
|
|
<Row>
|
|
<div style={{ flex: 1 }}>{children}</div>
|
|
<div className="image">{extraContent}</div>
|
|
</Row>
|
|
);
|
|
|
|
ReactDOM.render(
|
|
<PageHeader
|
|
title="Title"
|
|
className="site-page-header"
|
|
subTitle="This is a subtitle"
|
|
tags={<Tag color="blue">Running</Tag>}
|
|
extra={[
|
|
<Button key="3">Operation</Button>,
|
|
<Button key="2">Operation</Button>,
|
|
<Button key="1" type="primary">
|
|
Primary
|
|
</Button>,
|
|
<DropdownMenu key="more" />,
|
|
]}
|
|
avatar={{ src: 'https://avatars1.githubusercontent.com/u/8186664?s=460&v=4' }}
|
|
breadcrumb={{ routes }}
|
|
>
|
|
<Content
|
|
extraContent={
|
|
<img
|
|
src="https://gw.alipayobjects.com/zos/antfincdn/K%24NnlsB%26hz/pageHeader.svg"
|
|
alt="content"
|
|
width="100%"
|
|
/>
|
|
}
|
|
>
|
|
{content}
|
|
</Content>
|
|
</PageHeader>,
|
|
mountNode,
|
|
);
|
|
```
|
|
|
|
```css
|
|
#components-page-header-demo-content .image {
|
|
margin: 0 0 0 60px;
|
|
display: flex;
|
|
align-items: center;
|
|
}
|
|
|
|
#components-page-header-demo-content .ant-page-header-rtl .image {
|
|
margin: 0 60px 0 0;
|
|
}
|
|
|
|
#components-page-header-demo-content .example-link {
|
|
line-height: 24px;
|
|
margin-right: 16px;
|
|
}
|
|
[data-theme='compact'] #components-page-header-demo-content .example-link {
|
|
line-height: 20px;
|
|
}
|
|
#components-page-header-demo-content .example-link-icon {
|
|
margin-right: 8px;
|
|
}
|
|
|
|
[data-theme='compact'] #components-page-header-demo-content .example-link-icon {
|
|
width: 20px;
|
|
height: 20px;
|
|
}
|
|
|
|
#components-page-header-demo-content .ant-page-header-rtl .example-link {
|
|
float: right;
|
|
margin-right: 0;
|
|
margin-left: 16px;
|
|
}
|
|
#components-page-header-demo-content .ant-page-header-rtl .example-link-icon {
|
|
margin-right: 0;
|
|
margin-left: 8px;
|
|
}
|
|
|
|
@media (max-width: 768px) {
|
|
#components-page-header-demo-content .image {
|
|
flex: 100%;
|
|
margin: 24px 0 0;
|
|
}
|
|
}
|
|
```
|