mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-25 16:58:00 +08:00
436aa9ad2d
Co-authored-by: 梁朝飞 <liangchaofei@guokechuzhi.com> Co-authored-by: afc163 <afc163@gmail.com> Co-authored-by: thinkasany <480968828@qq.com>
67 lines
2.7 KiB
Markdown
67 lines
2.7 KiB
Markdown
---
|
||
category: Components
|
||
group: Data Display
|
||
title: Segmented
|
||
description: Display multiple options and allow users to select a single option.
|
||
cover: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*XJR2TbS1aaQAAAAAAAAAAAAADrJ8AQ/original
|
||
coverDark: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*-9tSSoO_MkIAAAAAAAAAAAAADrJ8AQ/original
|
||
demo:
|
||
cols: 2
|
||
---
|
||
|
||
This component is available since `antd@4.20.0`.
|
||
|
||
## When To Use
|
||
|
||
- When displaying multiple options and user can select a single option;
|
||
- When switching the selected option, the content of the associated area changes.
|
||
|
||
## Examples
|
||
|
||
<!-- prettier-ignore -->
|
||
<code src="./demo/basic.tsx">Basic</code>
|
||
<code src="./demo/vertical.tsx" version="5.21.0">Vertical Direction</code>
|
||
<code src="./demo/block.tsx">Block Segmented</code>
|
||
<code src="./demo/disabled.tsx">Disabled</code>
|
||
<code src="./demo/controlled.tsx">Controlled mode</code>
|
||
<code src="./demo/custom.tsx">Custom Render</code>
|
||
<code src="./demo/dynamic.tsx">Dynamic</code>
|
||
<code src="./demo/size.tsx">Three sizes of Segmented</code>
|
||
<code src="./demo/with-icon.tsx">With Icon</code>
|
||
<code src="./demo/icon-only.tsx">With Icon only</code>
|
||
<code src="./demo/controlled-two.tsx" debug>Controlled Synced mode</code>
|
||
<code src="./demo/size-consistent.tsx" debug>Consistent height</code>
|
||
<code src="./demo/componentToken.tsx" debug>Custom component token</code>
|
||
|
||
## API
|
||
|
||
Common props ref:[Common props](/docs/react/common-props)
|
||
|
||
> This component is available since `antd@4.20.0`
|
||
|
||
| Property | Description | Type | Default | Version |
|
||
| --- | --- | --- | --- | --- |
|
||
| block | Option to fit width to its parent\'s width | boolean | false | |
|
||
| defaultValue | Default selected value | string \| number | | |
|
||
| disabled | Disable all segments | boolean | false | |
|
||
| onChange | The callback function that is triggered when the state changes | function(value: string \| number) | | |
|
||
| options | Set children optional | string\[] \| number\[] \| SegmentedItemType\[] | [] | |
|
||
| size | The size of the Segmented. | `large` \| `middle` \| `small` | `middle` | |
|
||
| vertical | Orientation | boolean | `false` | 5.21.0 |
|
||
| value | Currently selected value | string \| number | | |
|
||
|
||
### SegmentedItemType
|
||
|
||
|
||
| Property | Description | Type | Default | Version |
|
||
| --- | --- | --- | --- | --- |
|
||
| label | Display text for Segmented item | ReactNode | - | |
|
||
| value | Value for Segmented item | string \| number | - | |
|
||
| icon | Display icon for Segmented item | ReactNode | - | |
|
||
| disabled | Disabled state of segmented item | boolean | false | |
|
||
| className | The additional css class | string | - | |
|
||
|
||
## Design Token
|
||
|
||
<ComponentTokenTable component="Segmented"></ComponentTokenTable>
|