ناوبری
ناوبری نوار ناوبری است که در بالای صفحه نمایش داده میشود و شامل عنوان سایت، لینکهای منوی جهانی، و غیره میباشد.
عنوان سایت و لوگو
به طور پیشفرض، ناو نام سایت را با ارجاع به مقدار config.title نمایش میدهد. اگر میخواهید تغییر دهید که چه چیزی در ناو نمایش داده شود، میتوانید متن سفارشی را در گزینه themeConfig.siteTitle تعریف کنید.
export default {
themeConfig: {
siteTitle: 'عنوان سفارشی من'
}
}اگر برای سایت خود لوگو دارید، میتوانید آن را با ارسال مسیر تصویر نمایش دهید. شما باید لوگو را در دایرکتوری public قرار داده و مسیر مطلق آن را تعریف کنید.
export default {
themeConfig: {
logo: '/my-logo.svg'
}
}هنگام افزودن یک لوگو، آن به همراه عنوان سایت نمایش داده میشود. اگر لوگوی شما همه چیزی است که نیاز دارید و اگر میخواهید متن عنوان سایت را پنهان کنید، گزینه siteTitle را برابر با false قرار دهید.
export default {
themeConfig: {
logo: '/my-logo.svg',
siteTitle: false
}
}همچنین میتوانید به عنوان لوگو یک شیء را نیز ارسال کنید اگر میخواهید ویژگی alt را اضافه کنید یا آن را بر اساس حالت تاریک / روشن سفارشیسازی کنید. برای جزئیات بیشتر به themeConfig.logo مراجعه کنید.
لینکهای ناوبری
شما میتوانید گزینه themeConfig.nav را تعریف کنید تا لینکها را به ناوبری خود اضافه کنید.
export default {
themeConfig: {
nav: [
{ text: 'راهنما', link: '/guide' },
{ text: 'پیکربندی', link: '/config' },
{ text: 'تغییرات', link: 'https://github.com/...' }
]
}
}text متن واقعی است که در ناوبری نمایش داده میشود و link لینکی است که هنگام کلیک بر روی متن به آن ناوبری میشود. برای لینک، مسیر را به صورت واقعی بدون پیشوند .md تنظیم کنید و همیشه با / شروع کنید.
link همچنین میتواند تابعی باشد که PageData را به عنوان آرگومان بپذیرد و مسیر را برگرداند.
لینکهای ناوبری همچنین میتوانند منوهای کشویی باشند. برای این کار، کلید items را در گزینه لینک تنظیم کنید.
export default {
themeConfig: {
nav: [
{ text: 'راهنما', link: '/guide' },
{
text: 'منوی کشویی',
items: [
{ text: 'مورد الف', link: '/item-1' },
{ text: 'مورد ب', link: '/item-2' },
{ text: 'مورد ج', link: '/item-3' }
]
}
]
}
}لطفا توجه داشته باشید که عنوان منوی کشویی (منوی کشویی در مثال بالا) نمیتواند خاصیت link داشته باشد زیرا این دکمه برای باز کردن صفحه گفتگوی کشویی میشود.
همچنین میتوانید بخشهایی را نیز به موارد منوی کشویی با ارسال موارد بیشتر تو در تو اضافه کنید.
export default {
themeConfig: {
nav: [
{ text: 'راهنما', link: '/guide' },
{
text: 'منوی کشویی',
items: [
{
// عنوان بخش
text: 'عنوان بخش A',
items: [
{ text: 'آیتم A بخش A', link: '...' },
{ text: 'آیتم B بخش B', link: '...' }
]
}
]
},
{
text: 'منوی کشویی',
items: [
{
// شما همچنین میتوانید عنوان را حذف کنید.
items: [
{ text: 'آیتم A بخش A', link: '...' },
{ text: 'آیتم B بخش B', link: '...' }
]
}
]
}
]
}
}سفارشیسازی وضعیت "فعال" لینک
موارد منوی ناوبری زمانی که صفحه فعلی زیر مسیر مطابقت دارد، مشخص میشوند. اگر میخواهید مسیر مطابقت را سفارشی کنید، ویژگی activeMatch و regex را به عنوان مقدار رشته تعریف کنید.
export default {
themeConfig: {
nav: [
// این لینک وضعیت فعال را در زمانی که کاربر در مسیر `/config/` است، دریافت میکند.
{
text: 'راهنما',
link: '/guide',
activeMatch: '/config/'
}
]
}
}هشدار
activeMatch انتظار میرود که به عنوان یک رشته regex باشد، اما شما باید آن را به عنوان یک رشته تعریف کنید. ما نمیتوانیم از شیء RegExp واقعی اینجا استفاده کنیم زیرا در زمان ساخت غیر قابل سریالیز کردن است.
سفارشیسازی ویژگیهای "target" و "rel" لینک
به طور پیشفرض، ویتپرس به طور خودکار ویژگیهای
target و rel را بر اساس اینکه لینک یک لینک خارجی است یا خیر، تعیین میکند. اما اگر میخواهید، شما همچنین میتوانید آنها را سفارشی کنید.
export default {
themeConfig: {
nav: [
{
text: 'کالای معاملاتی',
link: 'https://www.thegithubshop.com/',
target: '_self',
rel: 'sponsored'
}
]
}
}لینکهای اجتماعی
به socialLinks مراجعه کنید.
اجزای سفارشی
میتوانید اجزای سفارشی را در نوار ناوبری با استفاده از گزینه component اضافه کنید. کلید component باید نام مؤلفه Vue باشد و باید به صورت جهانی با استفاده از Theme.enhanceApp ثبت شود.
export default {
themeConfig: {
nav: [
{
text: 'منوی من',
items: [
{
component: 'MyCustomComponent',
// پارامترهای اختیاری برای ارسال به مؤلفه
props: {
title: 'مؤلفه سفارشی من'
}
}
]
},
{
component: 'AnotherCustomComponent'
}
]
}
}سپس، شما باید مؤلفه را به صورت جهانی ثبت کنید:
import DefaultTheme from 'vitepress/theme'
import MyCustomComponent from './components/MyCustomComponent.vue'
import AnotherCustomComponent from './components/AnotherCustomComponent.vue'
/** @type {import('vitepress').Theme} */
export default {
extends: DefaultTheme,
enhanceApp({ app }) {
app.component('MyCustomComponent', MyCustomComponent)
app.component('AnotherCustomComponent', AnotherCustomComponent)
}
}اجزای شما در نوار ناوبری نمایش داده خواهد شد. ویتپرس ویژگیهای اضافی زیر را به مؤلفه ارائه میدهد:
screenMenu: یک بولین اختیاری که نشان میدهد آیا مؤلفه در منوی ناوبری تلفن همراه است یا خیر
میتوانید یک نمونه را در آزمایشهای e2e اینجا بررسی کنید.