mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-09 21:38:54 +08:00
628968f460
* refactor: Using items * docs: replace with items * docs: deprecated demo * test: Update snapshot * docs: simple basic demo * test: coverage
61 lines
1.1 KiB
Markdown
61 lines
1.1 KiB
Markdown
---
|
|
order: 12
|
|
title:
|
|
zh-CN: 自定义页签头
|
|
en-US: Customized bar of tab
|
|
---
|
|
|
|
## zh-CN
|
|
|
|
使用 react-sticky 组件实现吸顶效果。
|
|
|
|
## en-US
|
|
|
|
Use react-sticky.
|
|
|
|
```tsx
|
|
import type { TabsProps } from 'antd';
|
|
import { Tabs } from 'antd';
|
|
import React from 'react';
|
|
import { Sticky, StickyContainer } from 'react-sticky';
|
|
|
|
const renderTabBar: TabsProps['renderTabBar'] = (props, DefaultTabBar) => (
|
|
<Sticky bottomOffset={80}>
|
|
{({ style }) => (
|
|
<DefaultTabBar {...props} className="site-custom-tab-bar" style={{ ...style }} />
|
|
)}
|
|
</Sticky>
|
|
);
|
|
|
|
const items = new Array(3).fill(null).map((_, i) => {
|
|
const id = String(i + 1);
|
|
return {
|
|
label: `Tab ${id}`,
|
|
key: id,
|
|
children: `Content of Tab Pane ${id}`,
|
|
style: i === 0 ? { height: 200 } : undefined,
|
|
};
|
|
});
|
|
|
|
const App: React.FC = () => (
|
|
<StickyContainer>
|
|
<Tabs defaultActiveKey="1" renderTabBar={renderTabBar} items={items} />
|
|
</StickyContainer>
|
|
);
|
|
|
|
export default App;
|
|
```
|
|
|
|
```css
|
|
.site-custom-tab-bar {
|
|
z-index: 1;
|
|
background: #fff;
|
|
}
|
|
```
|
|
|
|
<style>
|
|
[data-theme="dark"] .site-custom-tab-bar {
|
|
background: #141414;
|
|
}
|
|
</style>
|