86 lines
3.8 KiB
Markdown
86 lines
3.8 KiB
Markdown
|
|
---
|
||
|
|
title: useSelectedLayoutSegments
|
||
|
|
description: API Reference for the useSelectedLayoutSegments hook.
|
||
|
|
---
|
||
|
|
|
||
|
|
`useSelectedLayoutSegments` is a **Client Component** hook that lets you read the active route segments **below** the Layout it is called from.
|
||
|
|
|
||
|
|
It is useful for creating UI in parent Layouts that need knowledge of active child segments such as breadcrumbs.
|
||
|
|
|
||
|
|
```tsx filename="app/example-client-component.tsx" switcher
|
||
|
|
'use client'
|
||
|
|
|
||
|
|
import { useSelectedLayoutSegments } from 'next/navigation'
|
||
|
|
|
||
|
|
export default function ExampleClientComponent() {
|
||
|
|
const segments = useSelectedLayoutSegments()
|
||
|
|
|
||
|
|
return (
|
||
|
|
<ul>
|
||
|
|
{segments.map((segment, index) => (
|
||
|
|
<li key={index}>{segment}</li>
|
||
|
|
))}
|
||
|
|
</ul>
|
||
|
|
)
|
||
|
|
}
|
||
|
|
```
|
||
|
|
|
||
|
|
```jsx filename="app/example-client-component.js" switcher
|
||
|
|
'use client'
|
||
|
|
|
||
|
|
import { useSelectedLayoutSegments } from 'next/navigation'
|
||
|
|
|
||
|
|
export default function ExampleClientComponent() {
|
||
|
|
const segments = useSelectedLayoutSegments()
|
||
|
|
|
||
|
|
return (
|
||
|
|
<ul>
|
||
|
|
{segments.map((segment, index) => (
|
||
|
|
<li key={index}>{segment}</li>
|
||
|
|
))}
|
||
|
|
</ul>
|
||
|
|
)
|
||
|
|
}
|
||
|
|
```
|
||
|
|
|
||
|
|
> **Good to know**:
|
||
|
|
>
|
||
|
|
> - Since `useSelectedLayoutSegments` is a [Client Component](/docs/app/getting-started/server-and-client-components) hook, and Layouts are [Server Components](/docs/app/getting-started/server-and-client-components) by default, `useSelectedLayoutSegments` is usually called via a Client Component that is imported into a Layout.
|
||
|
|
> - The returned segments include [Route Groups](/docs/app/api-reference/file-conventions/route-groups), which you might not want to be included in your UI. You can use the [`filter`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter) array method to remove items that start with a bracket.
|
||
|
|
> - For [catch-all](/docs/app/api-reference/file-conventions/dynamic-routes#catch-all-segments) routes, the matched segments are returned as a single joined string within the array. For example, given `app/blog/[...slug]/page.js`, calling from `app/layout.js` when visiting `/blog/a/b/c` returns `['blog', 'a/b/c']`, not `['blog', 'a', 'b', 'c']`.
|
||
|
|
|
||
|
|
## Parameters
|
||
|
|
|
||
|
|
```tsx
|
||
|
|
const segments = useSelectedLayoutSegments(parallelRoutesKey?: string)
|
||
|
|
```
|
||
|
|
|
||
|
|
`useSelectedLayoutSegments` _optionally_ accepts a [`parallelRoutesKey`](/docs/app/api-reference/file-conventions/parallel-routes#with-useselectedlayoutsegments), which allows you to read the active route segment within that slot.
|
||
|
|
|
||
|
|
## Returns
|
||
|
|
|
||
|
|
`useSelectedLayoutSegments` returns an array of strings containing the active segments one level down from the layout the hook was called from. Or an empty array if none exist.
|
||
|
|
|
||
|
|
For example, given the Layouts and URLs below, the returned segments would be:
|
||
|
|
|
||
|
|
| Layout | Visited URL | Returned Segments |
|
||
|
|
| ------------------------- | --------------------- | --------------------------- |
|
||
|
|
| `app/layout.js` | `/` | `[]` |
|
||
|
|
| `app/layout.js` | `/dashboard` | `['dashboard']` |
|
||
|
|
| `app/layout.js` | `/dashboard/settings` | `['dashboard', 'settings']` |
|
||
|
|
| `app/dashboard/layout.js` | `/dashboard` | `[]` |
|
||
|
|
| `app/dashboard/layout.js` | `/dashboard/settings` | `['settings']` |
|
||
|
|
|
||
|
|
For catch-all routes (`[...slug]`), all matched path segments are returned as a single joined string within the array:
|
||
|
|
|
||
|
|
| Layout | Visited URL | Returned Segments |
|
||
|
|
| -------------------- | ------------- | ------------------- |
|
||
|
|
| `app/layout.js` | `/blog/a/b/c` | `['blog', 'a/b/c']` |
|
||
|
|
| `app/blog/layout.js` | `/blog/a/b/c` | `['a/b/c']` |
|
||
|
|
|
||
|
|
## Version History
|
||
|
|
|
||
|
|
| Version | Changes |
|
||
|
|
| --------- | --------------------------------------- |
|
||
|
|
| `v13.0.0` | `useSelectedLayoutSegments` introduced. |
|