2024-09-09 19:23:25 +08:00
---
category: Components
group: Layout
title: Splitter
2024-09-22 23:04:51 +08:00
description: Split panels to isolate
2024-09-11 13:51:04 +08:00
cover: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*f0SISaETY0wAAAAAAAAAAAAADrJ8AQ/original
coverDark: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*y92yRYhObU8AAAAAAAAAAAAADrJ8AQ/original
2024-09-09 19:23:25 +08:00
demo:
cols: 1
tag: 5.21.0
---
## When To Use
2024-09-22 23:04:51 +08:00
Can be used to separate areas horizontally or vertically. When you need to freely drag and adjust the size of each area. When you need to specify the maximum and minimum width and height of an area.
2024-09-09 19:23:25 +08:00
## Examples
<!-- prettier - ignore -->
< code src = "./demo/size.tsx" > Basic< / code >
< code src = "./demo/control.tsx" > Control mode< / code >
< code src = "./demo/vertical.tsx" > Vertical< / code >
< code src = "./demo/collapsible.tsx" > Collapsible< / code >
< code src = "./demo/multiple.tsx" > Multiple panels< / code >
< code src = "./demo/group.tsx" > Complex combination< / code >
< code src = "./demo/debug.tsx" debug > Debug< / code >
## API
Common props ref: [Common props](/docs/react/common-props)
2024-09-22 23:04:51 +08:00
> The Splitter component needs to calculate the panel size through its child elements, so its child elements only support `Splitter.Panel`.
2024-09-09 19:23:25 +08:00
### Splitter
| Property | Description | Type | Default | Version |
| --- | --- | --- | --- | --- |
| layout | Layout direction | `horizontal` \| `vertical` | `horizontal` | - |
| onResizeStart | Callback before dragging starts | `(sizes: number[]) => void` | - | - |
| onResize | Panel size change callback | `(sizes: number[]) => void` | - | - |
| onResizeEnd | Drag end callback | `(sizes: number[]) => void` | - | - |
### Panel
| Property | Description | Type | Default | Version |
| --- | --- | --- | --- | --- |
2024-09-11 00:03:02 +08:00
| defaultSize | Initial panel size support number for px or 'percent%' usage | `number \| string` | - | - |
2024-09-09 19:23:25 +08:00
| min | Minimum threshold support number for px or 'percent%' usage | `number \| string` | - | - |
| max | Maximum threshold support number for px or 'percent%' usage | `number \| string` | - | - |
| size | Controlled panel size support number for px or 'percent%' usage | `number \| string` | - | - |
| collapsible | Quick folding | `boolean \| { start?: boolean; end?: boolean }` | `false` | - |
| resizable | Whether to enable drag and drop | `boolean` | `true` | - |
## Design Token
< ComponentTokenTable component = 'Splitter' > < / ComponentTokenTable >