pengzhanbo 385059f214
docs: update en docs (#708)
* docs: update en docs

* chore: tweak

* chore: tweak

* chore: tweak
2025-10-09 15:46:05 +08:00

252 lines
6.8 KiB
Markdown

---
title: Navbar Configuration
createTime: 2025/10/09 15:07:33
permalink: /en/config/navigation/
---
## Overview
::: tip Navbar configuration can be set in either `.vuepress/config.ts` or `plume.config.ts`.
:::
The theme automatically generates the simplest navbar configuration by default, including only the **Home** and **Blog List** pages.
You can also configure the navbar yourself to override the default configuration.
The default configuration is as follows:
::: code-tabs#configs
@tab .vuepress/config.ts
```ts twoslash
import { defineUserConfig } from 'vuepress'
import { plumeTheme } from 'vuepress-theme-plume'
export default defineUserConfig({
theme: plumeTheme({
navbar: [
{ text: 'Home', link: '/' },
{ text: 'Blog', link: '/blog/' },
{ text: 'Tags', link: '/blog/tags/' },
{ text: 'Archives', link: '/blog/archives/' }
]
})
})
```
@tab .vuepress/plume.config.ts
```ts twoslash
import { defineThemeConfig } from 'vuepress-theme-plume'
export default defineThemeConfig({
navbar: [
{ text: 'Home', link: '/' },
{ text: 'Blog', link: '/blog/' },
{ text: 'Tags', link: '/blog/tags/' },
{ text: 'Archives', link: '/blog/archives/' }
]
})
```
:::
When multi-language configuration is enabled, the default navbar configuration for the corresponding languages will be generated:
```ts
import { defineUserConfig } from 'vuepress'
import { plumeTheme } from 'vuepress-theme-plume'
export default defineUserConfig({
lang: 'zh-CN',
locales: {
'/': { lang: 'zh-CN', title: '博客' }, // Simplified Chinese
'/en/': { lang: 'en-US', title: 'Blog' }, // English
},
theme: plumeTheme({
locales: {
'/': {
navbar: [
{ text: '首页', link: '/' },
{ text: '博客', link: '/blog/' },
{ text: '标签', link: '/blog/tags/' },
{ text: '归档', link: '/blog/archives/' }
]
},
'/en/': {
navbar: [
{ text: 'Home', link: '/en/' },
{ text: 'Blog', link: '/en/blog/' },
{ text: 'Tags', link: '/en/blog/tags/' },
{ text: 'Archives', link: '/en/blog/archives/' }
]
}
}
})
})
```
As your site content becomes richer, for example, when configuring collections for blog, notes, documentation,
friend links, external links, etc., the default generated navbar configuration may no longer meet your needs.
At this point, you can fully customize the navbar using the `navbar` field, which will directly override the default navbar configuration.
## Configuration
Type: `NavItem[]`
```ts
interface ThemeBadge {
/* Badge text */
text?: string
/* Badge type, built-in: 'info' | 'tip' | 'danger' | 'warning' */
type?: string
/* Text color */
color?: string
/* Background color */
bgColor?: string
/* Border color */
borderColor?: string
}
type NavItem = string | {
/**
* Navbar text
*/
text: string
/**
* Navbar link
* - Can be an external link
* - Can be a permalink from frontmatter
* - Can be a relative path to a markdown file (relative to `sourceDir`), must start with `/`
*/
link: string
/**
* Icon name, or SVG icon
*/
icon?: string | { svg: string }
/**
* Badge, supports custom badge styles
*/
badge?: string | ThemeBadge
/**
* Controls when the element is activated
*/
activeMatch?: string
/**
* Prefix for the current group of page links
*/
prefix?: string
/**
* Nested navbar items, maximum depth is 2
*/
items?: NavItem[]
}
```
### Nested Configuration Example
```ts title=".vuepress/config.ts"
import { defineUserConfig } from 'vuepress'
import { plumeTheme } from 'vuepress-theme-plume'
export default defineUserConfig({
theme: plumeTheme({
navbar: [
{ text: 'Home', link: '/', icon: 'material-symbols:home-outline' },
{ text: 'Blog', link: '/blog/', icon: 'material-symbols:article-outline' },
{
text: 'Technical Docs',
icon: 'mdi:idea',
items: [
{
text: 'Vuepress Theme',
icon: 'icon-park-solid:theme',
items: [
{
text: 'vuepress-theme-plume',
link: '/vuepress-theme-plume/',
icon: 'mdi:paper-airplane',
badge: 'Badge'
},
],
},
{
text: 'Vuepress Plugin',
icon: 'mingcute:plugin-2-fill',
badge: { text: 'Badge', type: 'warning' },
items: [
{
text: 'caniuse',
link: '/vuepress-plugin/caniuse/',
icon: 'pajamas:feature-flag',
},
{
text: 'auto-frontmatter',
link: '/vuepress-plugin/auto-frontmatter/',
icon: 'material-symbols:move-selection-down-rounded',
},
{
text: 'blog-data',
link: '/vuepress-plugin/blog-data/',
icon: 'ic:baseline-post-add',
},
{
text: 'notes-data',
link: '/vuepress-plugin/notes-data/',
icon: 'material-symbols:note-alt-rounded',
},
{
text: 'shiki',
link: '/vuepress-plugin/shiki/',
icon: 'material-symbols-light:code-blocks-outline-rounded',
},
],
},
],
},
]
})
})
```
### `activeMatch`
`activeMatch` is used to control when the current link element is activated. Its value is a regex-like string.
**Example:** `activeMatch: '^/(blog|article)/'`
This means that for page links starting with `/blog/` or `/article/`, this link element will be activated.
### Icons
Supports icons from sources configured via [markdown -> icon](../guide/features/icon.md).
- When `markdown.icon.provide` is `iconify`, [iconify](https://iconify.design/) icons are supported
- When `markdown.icon.provide` is `iconfont`, [iconfont](https://www.iconfont.cn/) icons are supported
- When `markdown.icon.provide` is `fontawesome`, [fontawesome](https://fontawesome.com/) icons are supported
When `markdown.icon.provide` is not `iconify`, you can prefix the icon name with `iconify` to force the
use of [iconify](https://iconify.design/) icons.
```ts
const item = { text: 'Home', link: '/', icon: 'iconify carbon:home' }
```
## Configuration Helper Function
The theme provides the `defineNavbarConfig(config)` function to offer type assistance for the navbar
configuration to theme users. This facilitates separating the `navbar` configuration into an independent configuration file.
```ts title="navbar.ts" twoslash
import { defineNavbarConfig } from 'vuepress-theme-plume'
export default defineNavbarConfig([
{ text: 'Home', link: '/' },
{ text: 'Blog', link: '/blog/' },
// ... more
])
```