Breadcrumbs, or a breadcrumb navigation, can help to enhance how users navigate to previous page levels of a website, especially if that website has many pages or products.
See CBreadcrumb
's accessibility report
Chakra UI exports 4 Breadcrumb related components:
CBreadcrumb
: The parent container for breadcrumbs.CBreadcrumbItem
: Individual breadcrumb element containing a link and a divider.CBreadcrumbLink
: The breadcrumb link, obviously.CBreadcrumbSeparator
: The visual separator between each breadcrumbimport {
CBreadcrumb,
CBreadcrumbItem,
CBreadcrumbLink,
CBreadcrumbSeparator,
} from "@chakra-ui/vue";
Add isCurrentPage
prop to the CBreadcrumbItem
that matches the current path.
When this prop is present, the CBreadcrumbItem
doesn't have a separator, and
the CBreadcrumbLink
has aria-current
set to page
.
<c-breadcrumb>
<c-breadcrumb-item>
<c-breadcrumb-link href="#">Breadcrumb 1</c-breadcrumb-link>
</c-breadcrumb-item>
<c-breadcrumb-item>
<c-breadcrumb-link href="#">Breadcrumb 2</c-breadcrumb-link>
</c-breadcrumb-item>
<c-breadcrumb-item isCurrentPage>
<c-breadcrumb-link href="#">Breadcrumb 2</c-breadcrumb-link>
</c-breadcrumb-item>
</c-breadcrumb>
Change the separator used in the CBreadrumb
by passing a string, like ›
.
<c-breadcrumb separator="›">
<c-breadcrumb-item>
<c-breadcrumb-link href="#">Breadcrumb 1</c-breadcrumb-link>
</c-breadcrumb-item>
<c-breadcrumb-item>
<c-breadcrumb-link href="#">Breadcrumb 2</c-breadcrumb-link>
</c-breadcrumb-item>
<c-breadcrumb-item isCurrentPage>
<c-breadcrumb-link href="#">Breadcrumb 2</c-breadcrumb-link>
</c-breadcrumb-item>
</c-breadcrumb>
To gain control over the style of the breadcrumb separator. Set add-separator
prop
on the CBreadcrumb
to false
, and manually add the CBreadcrumbSeparator
as a child of the
CBreadcrumbItem
.
You can then pass style props to change the styling of the CBreadcrumbSeparator
. You can also override
the content of the CBreadcrumbSeparator
by passing its default slot.
<c-breadcrumb :add-separator="false">
<c-breadcrumb-item>
<c-breadcrumb-link href="#">Breadcrumb 1</c-breadcrumb-link>
<c-breadcrumb-separator color="tomato" font-size="10px" font-weight="bold" />
</c-breadcrumb-item>
<c-breadcrumb-item>
<c-breadcrumb-link href="#">Breadcrumb 2</c-breadcrumb-link>
<c-breadcrumb-separator color="firebrick" font-size="20px" />
</c-breadcrumb-item>
<c-breadcrumb-item isCurrentPage>
<c-breadcrumb-link href="#">Breadcrumb 2</c-breadcrumb-link>
</c-breadcrumb-item>
</c-breadcrumb>
CBreadcrumb
composes CBox so you can pass all CBox
props to change the
style of the breadcrumbs. Let's say we need to increase the font-size
of the
breadcrumbs.
<c-breadcrumb font-weight="medium" font-size="sm">
<c-breadcrumb-item>
<c-breadcrumb-link href="/google">Home</c-breadcrumb-link>
</c-breadcrumb-item>
<c-breadcrumb-item>
<c-breadcrumb-link href="/about">About</c-breadcrumb-link>
</c-breadcrumb-item>
<c-breadcrumb-item isCurrentPage>
<c-breadcrumb-link href="/current">Current</c-breadcrumb-link>
</c-breadcrumb-item>
</c-breadcrumb>
To use the CBreadcrumb
with a routing Library like Vue Router,
all you need to do is to pass the as
prop to the CBreadcrumbLink
component.
It'll replace the rendered a
tag with with router-link
or nuxt-link
.
<c-breadcrumb separator="›">
<c-breadcrumb-item>
<c-breadcrumb-link as="nuxt-link" to="/">Components</c-breadcrumb-link>
</c-breadcrumb-item>
<c-breadcrumb-item>
<c-breadcrumb-link as="nuxt-link" to="/breadcrumb">Breadcrumb</c-breadcrumb-link>
</c-breadcrumb-item>
</c-breadcrumb>
nav
to denote that it's a navigation
landmark.CBreadcrumb
nav
has aria-label
set to breadcrumb
.CBreadcrumbItem
with isCurrentPage
prop adds the aria-current=page
to
the CBreadcrumbLink
.role
set to presentation
to denote that its for
presentation purposes.CBreadcrumb
Props#Name | Type | Default | Description |
---|---|---|---|
separator | string | / | The visual separator between the breadcrumb item. |
spacing | StyledSystem.MarginProps | 0.5rem | The left and right margin applied to the separator. |
addSeparator | boolean | true | If true , the breadcrumb will add the separator automatically. |
CBreadcrumbItem
Props#Name | Type | Default | Description |
---|---|---|---|
isCurrentPage | boolean | false | If true , it indicates that the breadcrumb link is active page, adds aria-current=page and renders a span |
CBreadcrumbLink
Props#The CBreadcrumbLink
composes the CLink component so it accepts all CLink props.
The BreadcrumbSeparator composes the CBox component so it accepts all CBox props.
Caught a mistake or want to contribute to the documentation? Edit this page on GitHub!