Tabs

An accessible tabs component.

The CTab and CTabPanel elements are associated by their order in the tree. None of the components are empty wrappers, each is associated with a real DOM element in the document, giving you maximum control over styling and composition.

Import#

import { CTabs, CTabList, CTabPanels, CTab, CTabPanel } from '@chakra-ui/vue'

Usage#

You can render any element within CTabs, but CTabList should only have CTab as children, and CTabPanels should have CTabPanel as children.

Tabs expects CTabList and CTabPanels as children. The order doesn't matter, you can have tabs at the top, at the bottom, or both.

one!

Editable Example
<c-box w="600px">
    <c-tabs>
        <c-tab-list>
        <c-tab>One</c-tab>
        <c-tab>Two</c-tab>
        <c-tab>Three</c-tab>
        </c-tab-list>
        
        <c-tab-panels>
        <c-tab-panel>
            <p>one!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>two!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>three!</p>
        </c-tab-panel>
        </c-tab-panels>
    </c-tabs>
</c-box>

Tab variants and color#

Tabs come in 6 different variants to style the tabs: line,enclosed, enclosed-colored, soft-rounded, solid-rounded, unstyled

one!

Editable Example
<c-box>
    <c-tabs variant="enclosed">
        <c-tab-list>
        <c-tab>One</c-tab>
        <c-tab>Two</c-tab>
        <c-tab>Three</c-tab>
        </c-tab-list>

        <c-tab-panels>
        <c-tab-panel>
            <p>one!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>two!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>three!</p>
        </c-tab-panel>
        </c-tab-panels>
    </c-tabs>
</c-box>

You can also change the color for any specific variant by passing the variantColor.

The value of variantColor must exist in the theme object, and must be a key in theme.colors that has the 100 - 900 color values.

one!

Editable Example
<c-box>
    <c-tabs variant="soft-rounded" variant-color="green">
        <c-tab-list>
        <c-tab>One</c-tab>
        <c-tab>Two</c-tab>
        <c-tab>Three</c-tab>
        </c-tab-list>
        
        <c-tab-panels>
        <c-tab-panel>
            <p>one!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>two!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>three!</p>
        </c-tab-panel>
        </c-tab-panels>
    </c-tabs>
</c-box>

Tab sizes#

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

one!

Editable Example
<c-box>
    <c-tabs variant="solid-rounded" size="sm" variant-color="green">
        <c-tab-list>
        <c-tab>One</c-tab>
        <c-tab>Two</c-tab>
        <c-tab>Three</c-tab>
        </c-tab-list>

        <c-tab-panels>
        <c-tab-panel>
            <p>one!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>two!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>three!</p>
        </c-tab-panel>
        </c-tab-panels>
    </c-tabs>
</c-box>

Change the tabs alignment#

You can change the alignment of the TabList by passing align prop. We support 3 sizes start, center, end.

one!

Editable Example
<c-box>
    <c-tabs variant="enclosed-colored" variant-color="vue" align="end">
        <c-tab-list>
        <c-tab>One</c-tab>
        <c-tab>Two</c-tab>
        <c-tab>Three</c-tab>
        </c-tab-list>

        <c-tab-panels>
        <c-tab-panel>
            <p>one!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>two!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>three!</p>
        </c-tab-panel>
        </c-tab-panels>
    </c-tabs>
</c-box>

Fitted Tabs#

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

one!

Editable Example
<c-box>
    <c-tabs variant="enclosed-colored" is-fitted>
        <c-tab-list>
        <c-tab>One</c-tab>
        <c-tab>Two</c-tab>
        <c-tab>Three</c-tab>
        </c-tab-list>

        <c-tab-panels>
        <c-tab-panel>
            <p>one!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>two!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>three!</p>
        </c-tab-panel>
        </c-tab-panels>
    </c-tabs>
</c-box>

Make a tab initally active#

three!

Editable Example
<c-box>
    <c-tabs variant="enclosed-colored" :default-index="2">
        <c-tab-list>
        <c-tab>One</c-tab>
        <c-tab>Two</c-tab>
        <c-tab>Three</c-tab>
        </c-tab-list>

        <c-tab-panels>
        <c-tab-panel>
            <p>one!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>two!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>three!</p>
        </c-tab-panel>
        </c-tab-panels>
    </c-tabs>
</c-box>

Make a Tab disabled#

one!

Editable Example
<c-box>
    <c-tabs variant="enclosed-colored">
        <c-tab-list>
        <c-tab>One</c-tab>
        <c-tab>Two</c-tab>
        <c-tab is-disabled>Three</c-tab>
        </c-tab-list>

        <c-tab-panels>
        <c-tab-panel>
            <p>one!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>two!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>three!</p>
        </c-tab-panel>
        </c-tab-panels>
    </c-tabs>
</c-box>

Manually Activated Tabs#

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

The content of a CTabPanel should ideally be preloaded. However, if switching to a tab panel causes a network request and possibly a page refresh, there might be some notable latency and this might affect the experience for keyboard and screen reader users.

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

one!

Editable Example
<c-box>
    <c-tabs is-manual variant="enclosed">
        <c-tab-list>
        <c-tab>One</c-tab>
        <c-tab>Two</c-tab>
        <c-tab>Three</c-tab>
        </c-tab-list>

        <c-tab-panels>
        <c-tab-panel>
            <p>one!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>two!</p>
        </c-tab-panel>
        <c-tab-panel>
            <p>three!</p>
        </c-tab-panel>
        </c-tab-panels>
    </c-tabs>
</c-box>

Accessibility#

Keyboard#

KeyAction
ArrowLeftMoves focus to the next tab
ArrowUpMoves 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's 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 TabPanel
TabListidThe id of the TabPanel that's referencd by its associated Tab
aria-orientationSet to vertical or horizontal based on the value of the orientation prop.
role="tablist"Indicates that it's a tablist
aria-labelledbySet to the id of the Tab that labels the TabPanel.

Props#

Tabs Props#

Tabs composes Box so you call pass all Box related props.

NameTypeDefaultDescription
indexnumberThe controlled index of the tabs.
defaultIndexnumberThe index of the initial active tab.
isManualbooleanIf true, keyboard navigation changes focus between tabs but doens't activate it. User will have to press Enter to active it
variantline,enclosed,enclosed-colored, soft-rounded, solid-rounded, unstyledlineThe visual style of the tab.
variantColorstringThe primary color to use for the selected variant. Use a color key in theme.colors
sizesm, md, lgmdThe visual size of the tabs
orientationhorizontal, verticalhorizontalThe orientation of the tabs
isFittedbooleanIf true, the tabs will stretch to fill the available space

Tabs Events#

NameDescription
@changeEvent emitted when the active tab changes.

Tabs Slot#

NameDescription
defaultThe children of the CTabs component.

Tab Props#

NameTypeDefaultDescription
isDisabledbooleanIf true, the tab will be disabled

❤️ Contribute to this page

Caught a mistake or want to contribute to the documentation? Edit this page on GitHub!