# API زمان اجرا {#runtime-api} ویت‌پرس چندین API داخلی را ارائه می‌دهد تا به شما امکان دسترسی به داده‌های برنامه را بدهد. همچنین، ویت‌پرس با چندین کامپوننت داخلی همراه است که می‌توانید به صورت جهانی از آن‌ها استفاده کنید. متدهای کمکی به صورت جهانی از `vitepress` قابل وارد کردن هستند و معمولاً در کامپوننت‌های Vue سفارشی تم استفاده می‌شوند. با این حال، آن‌ها همچنین در صفحات `.md` قابل استفاده هستند زیرا فایل‌های markdown به [کامپوننت‌های فایل تکی](https://vuejs.org/guide/scaling-up/sfc.html) Vue ترجمه می‌شوند. متدهایی که با `use*` آغاز می‌شوند نشان می‌دهند که این یک تابع [API ترکیبی Vue 3](https://vuejs.org/guide/introduction.html#composition-api) ("Composable") است که فقط می‌تواند در `setup()` یا ` ``` ## `useRoute` {#useroute} شیء مسیر فعلی را با این نوع برمی‌گرداند: ```ts interface Route { path: string data: PageData component: Component | null } ``` ## `useRouter` {#userouter} نمونه راوتر ویت‌پرس را برمی‌گرداند تا بتوانید به صورت برنامه‌ریزی‌شده به صفحه دیگری ناوبری کنید. ```ts interface Router { /** * Route فعلی */ route: Route /** * به URL جدید ناوبری کنید. */ go: (to?: string) => Promise /** * قبل از تغییر مسیر فراخوانی می‌شود. برای لغو ناوبری `false` را برگردانید. */ onBeforeRouteChange?: (to: string) => Awaitable /** * قبل از بارگذاری مؤلفه صفحه فراخوانی می‌شود (پس از به‌روزرسانی وضعیت تاریخچه). برای لغو ناوبری `false` را برگردانید. */ onBeforePageLoad?: (to: string) => Awaitable /** * پس از تغییر مسیر فراخوانی می‌شود. */ onAfterRouteChange?: (to: string) => Awaitable } ``` ## `withBase` {#withbase} - **نوع**: `(path: string) => string` پایه [پیکربندی‌شده](./site-config#base) را به یک مسیر URL داده شده اضافه می‌کند. همچنین به [آدرس پایه](../guide/asset-handling#base-url) مراجعه کنید. ## `` {#content} کامپوننت `` محتوای markdown را نمایش می‌دهد. مفید است [هنگام ایجاد تم شخصی شما](../guide/custom-theme). ```vue ``` ## `` {#clientonly} کامپوننت `` فقط اسلات خود را در سمت مشتری رندر می‌کند. چون برنامه‌های ویت‌پرس هنگام ایجاد از سمت سرور در Node.js رندر می‌شوند، هر استفاده از Vue باید به الزامات کد یکپارچه دنیا پاسخ دهد. به طور خلاصه، اطمینان حاصل کنید که فقط در قالب hooks `beforeMount` یا `mounted` به API‌های Browser / DOM دسترسی دارید. اگر از کامپوننت‌هایی استفاده یا نمایش دهنده‌هایی که با SSR سازگار نیستند (مانند دستورالعمل‌های سفارشی) استفاده می‌کنید، می‌توانید آن‌ها را داخل کامپوننت `ClientOnly` قرار دهید. ```vue-html ``` - مرتبط: [سازگاری با SSR](../guide/ssr-compat) ## `$frontmatter` {#frontmatter} در بیانیه‌های Vue، به صورت مستقیم به [داده‌های frontmatter](../guide/frontmatter) صفحه فعلی دسترسی پیدا کنید. ```md --- title: سلام --- # {{ $frontmatter.title }} ``` ## `$params` {#params} در بیانیه‌های Vue، به صورت مستقیم به [پارامترهای مسیر دینامیک](../guide/routing#dynamic-routes) صفحه فعلی دسترسی پیدا کنید. ```md - نام بسته: {{ $params.pkg }} - نسخه: {{ $params.version }} ```