Tabs

A React component that helps you build accessible tabs, by providing keyboard interactions and ARIA attributes described in the WAI-ARIA Tab Panel Design Pattern.

Source

Import#

import { Tabs } from '@chakra-ui/react'

Usage#

Tab requires the value prop to be passed to both the Tabs.Trigger and the Tabs.Content components. This is used to associate the tab with its content.

<Tabs.Root defaultValue='one'>
<Tabs.List>
<Tabs.Trigger value='one'>One</Tabs.Trigger>
<Tabs.Trigger value='two'>Two</Tabs.Trigger>
<Tabs.Trigger value='three'>Three</Tabs.Trigger>
</Tabs.List>
<Tabs.ContentGroup>
<Tabs.Content value='one'>
<p>one!</p>
</Tabs.Content>
<Tabs.Content value='two'>
<p>two!</p>
</Tabs.Content>
<Tabs.Content value='three'>
<p>three!</p>
</Tabs.Content>
</Tabs.ContentGroup>
</Tabs.Root>

Changing the variant#

Tabs come in 6 different variants to style the tabs: line,enclosed, outline, and plain

<Tabs.Root defaultValue='one'>
<Tabs.List>
<Tabs.Trigger value='one'>One</Tabs.Trigger>
<Tabs.Trigger value='two'>Two</Tabs.Trigger>
</Tabs.List>
<Tabs.ContentGroup>
<Tabs.Content value='one'>
<p>one!</p>
</Tabs.Content>
<Tabs.Content value='two'>
<p>two!</p>
</Tabs.Content>
</Tabs.ContentGroup>
</Tabs.Root>

Changing the color palette#

Set the colorPalette prop to change the color of the tabs. This will change the color of the active tab and the active tab indicator.

<Tabs.Root defaultValue='one' colorPalette='teal'>
<Tabs.List>
<Tabs.Trigger value='one'>Tab 1</Tabs.Trigger>
<Tabs.Trigger value='two'>Tab 2</Tabs.Trigger>
</Tabs.List>
<Tabs.ContentGroup>
<Tabs.Content value='one'>
<p>one!</p>
</Tabs.Content>
<Tabs.Content value='two'>
<p>two!</p>
</Tabs.Content>
</Tabs.ContentGroup>
</Tabs.Root>

Changing the size of the tab#

You can change the size of the tab by passing size prop. We support 3 sizes sm, md, lg

<Tabs.Root defaultValue='one' size='sm'>
<Tabs.List>
<Tabs.Trigger value='one'>Tab 1</Tabs.Trigger>
<Tabs.Trigger value='two'>Tab 2</Tabs.Trigger>
</Tabs.List>
<Tabs.ContentGroup>
<Tabs.Content value='one'>
<p>one!</p>
</Tabs.Content>
<Tabs.Content value='two'>
<p>two!</p>
</Tabs.Content>
</Tabs.ContentGroup>
</Tabs.Root>

Changing the alignment of the tab list#

You can change the alignment of the TabList by passing justify prop. The values are start, center, end.

<Tabs.Root defaultValue='one' justify='end'>
<Tabs.List>
<Tabs.Trigger value='one'>Tab 1</Tabs.Trigger>
<Tabs.Trigger value='two'>Tab 2</Tabs.Trigger>
</Tabs.List>
<Tabs.ContentGroup>
<Tabs.Content value='one'>
<p>one!</p>
</Tabs.Content>
<Tabs.Content value='two'>
<p>two!</p>
</Tabs.Content>
</Tabs.ContentGroup>
</Tabs.Root>

Fitted Tabs#

Stretch the tab list to fit the container by passing fitted prop.

<Tabs.Root defaultValue='one' fitted>
<Tabs.List>
<Tabs.Trigger value='one'>Tab 1</Tabs.Trigger>
<Tabs.Trigger value='two'>Tab 2</Tabs.Trigger>
</Tabs.List>
<Tabs.ContentGroup>
<Tabs.Content value='one'>
<p>one!</p>
</Tabs.Content>
<Tabs.Content value='two'>
<p>two!</p>
</Tabs.Content>
</Tabs.ContentGroup>
</Tabs.Root>

Rendering an indicator#

You can render a custom indicator by rendering the Tabs.Indicator component within the Tabs.List component.

<Tabs.Root defaultValue='one' unstyled>
<Tabs.List>
<Tabs.Trigger value='one'> One</Tabs.Trigger>
<Tabs.Trigger value='two'>Two</Tabs.Trigger>
<Tabs.Trigger value='three'>Three</Tabs.Trigger>
<Tabs.Indicator mt='-1.5px' height='2px' bg='teal.600' borderRadius='1px' />
</Tabs.List>
<Tabs.ContentGroup>
<Tabs.Content value='one'>
<p>one!</p>
</Tabs.Content>
<Tabs.Content value='two'>
<p>two!</p>
</Tabs.Content>
<Tabs.Content value='three'>
<p>three!</p>
</Tabs.Content>
</Tabs.ContentGroup>
</Tabs.Root>

Styling the tab states via props#

In the event that you need to create custom styles for individual tabs, use the _selected, _hover, _active style props.

<Tabs.Root defaultValue='one' variant='unstyled'>
<Tabs.List>
<Tabs.Trigger value='one' _selected={{ color: 'white', bg: 'blue.500' }}>
Tab 1
</Tabs.Trigger>
<Tabs.Trigger value='two' _selected={{ color: 'white', bg: 'green.400' }}>
Tab 2
</Tabs.Trigger>
</Tabs.List>
<Tabs.ContentGroup>
<Tabs.Content value='one'>
<p>one!</p>
</Tabs.Content>
<Tabs.Content value='two'>
<p>two!</p>
</Tabs.Content>
</Tabs.ContentGroup>
</Tabs.Root>

Listening to tab changes#

The onChange callback returns the active tab's value whenever the user changes tabs.

<Tabs.Root defaultValue='red' onChange={(value) => setValue(value)}>
<Tabs.List>
<Tabs.Trigger value='red'>Red</Tabs.Trigger>
<Tabs.Trigger value='teal'>Teal</Tabs.Trigger>
<Tabs.Trigger value='blue'>Blue</Tabs.Trigger>
</Tabs.List>
<Tabs.ContentGroup p='2rem'>
<Tabs.Content value='red'>The Primary Colors</Tabs.Content>
<Tabs.Content value='teal'>Are 1, 2, 3</Tabs.Content>
<Tabs.Content value='blue'>Red, yellow and blue.</Tabs.Content>
</Tabs.ContentGroup>
</Tabs.Root>

Setting the initially selected tab#

If you want a tab to be initially active, simply pass the defaultValue prop

<Tabs.Root defaultValue='naruto'>
<Tabs.ContentGroup>
<Tabs.Content value='naruto'>
<Image
boxSize='200px'
fit='cover'
src='https://www.freepnglogos.com/uploads/naruto-png/image-kunai-naruto-fictional-battle-omniverse-23.png'
/>
</Tabs.Content>
<Tabs.Content value='sasuke'>
<Image
boxSize='200px'
fit='cover'
src='https://images5.alphacoders.com/810/thumbbig-810547.webp'
/>
</Tabs.Content>
</Tabs.ContentGroup>
<Tabs.List>
<Tabs.Trigger value='naruto'>Naruto</Tabs.Trigger>
<Tabs.Trigger value='sasuke'>Sasuke</Tabs.Trigger>
</Tabs.List>
</Tabs.Root>

Disabling a tab#

When a Tabs.Trigger is disabled, it is skipped during keyboard navigation and it is not clickable.

function Example() {
return (
<Tabs.Root defaultValue='one'>
<Tabs.List>
<Tabs.Trigger value="one">One</Tabs.Trigger>
<Tabs.Trigger disabled value="two">Two</Tabs.Trigger>
<Tabs.Trigger value="three">Three</Tabs.Trigger>
</Tabs.List>
<Tabs.ContentGroup>
<Tabs.Content value="one">1</Tabs.Conte>
<Tabs.Content value="two">2</Tabs.Conte>
<Tabs.Content value="three">3</Tabs.Conte>
</Tabs.ContentGroup>
</Tabs.Root>
)
}

Tabs with manual activation#

By default, Tabs are activated automatically. This means when you use the arrow keys to change tabs, the tab is activated and focused.

In this scenario, you should use a manually activated tab, it moves focus without activating the tabs. With focus on a specific tab, users can activate a tab by pressing Space or Enter.

<Tabs.Root defaultValue='one' activationMode='manual'>
<Tabs.List>
<Tabs.Trigger value='one'>One</Tabs.Trigger>
<Tabs.Trigger value='two'>Two</Tabs.Trigger>
</Tabs.List>
<Tabs.ContentGroup>
<Tabs.Content value='one'>
<p>one!</p>
</Tabs.Content>
<Tabs.Content value='two'>
<p>two!</p>
</Tabs.Content>
</Tabs.ContentGroup>
</Tabs.Root>

Lazily mounting tab panels#

By default, the Tabs component renders all tabs content to the DOM, meaning that invisible tabs are still rendered but are hidden by styles.

Set the lazyMount prop to defer rendering of each tab until that tab is selected.

This is useful if your tabs require heavy performance

<Tabs.Root defaultValue='one' lazyMount>
<Tabs.List>
<Tabs.Trigger value='one'>One</Tabs.Trigger>
<Tabs.Trigger value='two'>Two</Tabs.Trigger>
</Tabs.List>
<Tabs.ContentGroup>
<Tabs.Content value='one'>
<p>one!</p>
</Tabs.Content>
<Tabs.Content value='two'>
<p>two!</p>
</Tabs.Content>
</Tabs.ContentGroup>
</Tabs.Root>

Controlled Tabs#

To control the selected tab programmatically, you can pass the value and onChange props to the Tabs.Root component.

function ControlledExample() {
const [value, setValue] = useState('one')
const tabs = ['one', 'two', 'three']
return (
<Tabs.Root defaultValue='one' value={value} onChange={setValue}>
<Tabs.List>
<Tabs.Trigger value='one'>One</Tabs.Trigger>
<Tabs.Trigger value='two'>Two</Tabs.Trigger>
<Tabs.Trigger value='three'>Three</Tabs.Trigger>
</Tabs.List>
<Tabs.ContentGroup>
<Tabs.Content value='one'>
<p>Click the tabs or pull the slider around</p>
</Tabs.Content>
<Tabs.Content value='two'>
<p>Yeah yeah. What's up?</p>
</Tabs.Content>
<Tabs.Content value='three'>
<p>Oh, hello there.</p>
</Tabs.Content>
</Tabs.ContentGroup>
</Tabs.Root>
)
}

Accessibility#

Keyboard#

KeyAction
ArrowLeftMoves focus to the next tab
ArrowRightMoves focus to the previous tab
TabWhen focus moves into the tab list, places focus on the active tab element
Space or EnterActivates the tab if it was not activated automatically on focus
HomeMoves focus to the first tab
EndMoves focus to the last tab

ARIA roles#

ComponentAriaUsage
Tabrole="tab"Indicates that it is a tab
aria-selectedSet to true a tab is selected and all other Tabs have it set to false
aria-controlsSet to the id of its associated Tabs.Content
Tabs.TriggeridThe id of the Tabs.Content that's referenced by its associated Tab
aria-orientationSet to vertical or horizontal based on the value of the orientation prop
role="tablist"Indicates that it is a tablist
Tabs.Contentrole="Tabs.Content"Indicates that it is a Tabs.Content
aria-labelledbySet to the id of the Tab that labels the Tabs.Content
Edit this page on GitHub

Proudly made inNigeria by Segun Adebayo

Deployed by â–² Vercel