021-88881776

آموزش مسیریابی (Routing) Vue.js

اگر به دنبال یادگیری Vue.js هستید و می‌خواهید با یکی از بخش‌های کلیدی این فریم‌ورک یعنی مسیریابی (Routing) Vue.js آشنا شوید، این مقاله برای شماست. در این آموزش Vue.js، از مفاهیم پایه مسیریابی گرفته تا تکنیک‌های پیشرفته مانند گاردهای مسیریابی و بارگذاری تنبل را پوشش خواهیم داد. با مطالعه این مقاله، می‌توانید مسیریابی را در پروژه‌های خود به صورت حرفه‌ای پیاده‌سازی کنید.

مسیریابی (Routing) چیست؟

مسیریابی (Routing) فرآیندی است که کاربران را در یک برنامه وب بین صفحات یا بخش‌های مختلف هدایت می‌کند. در برنامه‌های وب سنتی، تغییر صفحات معمولاً نیاز به بارگذاری مجدد کل صفحه داشت. این کار نه‌تنها باعث کاهش سرعت و تجربه کاربری می‌شد، بلکه منابع سرور را نیز بیشتر مصرف می‌کرد. اما در برنامه‌های وب تک‌صفحه‌ای (SPA)، همه بخش‌های برنامه در یک صفحه HTML بارگذاری می‌شوند و مسیریابی به صورت پویا و بدون نیاز به بارگذاری مجدد انجام می‌شود.

مزایای مسیریابی در SPAها

تجربه کاربری بهتر: کاربران می‌توانند بدون انتظار برای بارگذاری صفحه جدید، به سرعت بین بخش‌های مختلف جابه‌جا شوند.
بهینه‌سازی منابع: تنها بخش‌های موردنیاز به‌روزرسانی می‌شوند که باعث کاهش مصرف منابع سرور و شبکه می‌شود.
پشتیبانی از URL‌ها: حتی در SPAها، مسیریابی به کاربران اجازه می‌دهد از URL‌های جداگانه برای بخش‌های مختلف برنامه استفاده کنند. این قابلیت برای اشتراک‌گذاری لینک‌ها و بهبود سئو مفید است.

نقش Vue Router در مسیریابی

در Vue.js، کتابخانه Vue Router ابزار رسمی برای مدیریت مسیریابی است. این کتابخانه ویژگی‌های متنوعی از جمله مسیریابی پویا، مسیرهای تو در تو، گاردهای مسیریابی، و بارگذاری تنبل را ارائه می‌دهد. با استفاده از Vue Router، می‌توانید تجربه‌ای روان و حرفه‌ای برای کاربران ایجاد کنید.
مثال ساده

فرض کنید برنامه‌ای دارید که دو بخش “خانه” و “درباره ما” دارد. مسیریابی به شما اجازه می‌دهد که به جای بارگذاری یک صفحه کامل، تنها کامپوننت مرتبط با بخش انتخابی کاربر را نمایش دهید.

برای این کار، مسیرها به صورت زیر تعریف می‌شوند:

const routes = [
  { path: '/', component: Home },
  { path: '/about', component: About },
];

سپس Vue Router مسیر مناسب را با کامپوننت مرتبط تطبیق داده و همان را در صفحه نمایش می‌دهد.

با مسیریابی در SPAها، برنامه‌های وب از عملکردی مشابه با برنامه‌های دسکتاپ برخوردار می‌شوند و بهبود بزرگی در تجربه کاربری ایجاد می‌کنند. مسیریابی (Routing) Vue.js یکی از بهترین ابزارها برای پیاده‌سازی این ویژگی‌ها است.

معرفی Vue Router

Vue Router کتابخانه رسمی برای مدیریت مسیریابی در Vue.js است که امکان ایجاد تجربه کاربری روان و مدرن در برنامه‌های وب تک‌صفحه‌ای (SPA) را فراهم می‌کند. این ابزار به شما اجازه می‌دهد تا مسیرها را تعریف کرده و با توجه به آدرس URL، کامپوننت‌های مرتبط را در برنامه نمایش دهید. Vue Router دارای ویژگی‌های قدرتمند مانند مسیریابی پویا، مسیرهای تو در تو، گاردهای مسیریابی، و بارگذاری تنبل است که برای پروژه‌های کوچک و بزرگ بسیار مناسب می‌باشد.

ویژگی‌های کلیدی Vue Router

تعریف مسیرها: به شما امکان می‌دهد تا مسیرهای مختلف برنامه را به سادگی تنظیم کنید و هر مسیر را به یک کامپوننت متصل کنید.
مسیریابی پویا: مسیرهایی را با متغیرهایی مانند :id تعریف کنید که در مواقع خاص مقدار می‌گیرند.
مسیرهای تو در تو: برای سازمان‌دهی بهتر صفحات و اجزای داخلی، مسیرهای تو در تو را پیاده‌سازی کنید.
گاردهای مسیریابی: کنترل دسترسی به صفحات خاص بر اساس شرایط مانند احراز هویت.
بارگذاری تنبل (Lazy Loading): کامپوننت‌ها تنها زمانی بارگذاری شوند که کاربر به آن‌ها نیاز دارد، که باعث افزایش سرعت اولیه برنامه می‌شود.

نصب Vue Router

برای شروع استفاده از Vue Router، ابتدا باید آن را نصب کنید. اگر Vue.js قبلاً در پروژه شما نصب شده است، می‌توانید با استفاده از npm یا yarn این کتابخانه را اضافه کنید:

npm install vue-router
# یا
yarn add vue-router

تنظیم اولیه Vue Router

بعد از نصب، نیاز است که Vue Router را به پروژه خود اضافه کرده و مسیرهای مختلف را تعریف کنید. این فرآیند شامل مراحل زیر است:

1. تعریف مسیرها

ابتدا مسیرهای خود را در یک فایل مشخص (مانند router.js) تعریف کنید. هر مسیر شامل آدرس (path) و کامپوننتی است که باید در آن آدرس نمایش داده شود:

import { createRouter, createWebHistory } from 'vue-router';
import Home from './components/Home.vue';
import About from './components/About.vue';

const routes = [
  { path: '/', component: Home },
  { path: '/about', component: About },
];

2. ایجاد نمونه‌ای از Router

با استفاده از متد createRouter، نمونه‌ای از Vue Router ایجاد کنید و تاریخچه مرورگر را با createWebHistory تنظیم نمایید. این متد از API مدرن مرورگر برای مدیریت تاریخچه استفاده می‌کند.

const router = createRouter({
  history: createWebHistory(),
  routes, // مسیرهای تعریف شده
});

3. اتصال Vue Router به پروژه

برای فعال‌سازی مسیریابی در برنامه، نمونه Router را به Vue app اصلی متصل کنید:

import { createApp } from 'vue';
import App from './App.vue';
import router from './router';

const app = createApp(App);
app.use(router); // استفاده از Vue Router
app.mount('#app');

 

نمونه کاربردی Vue Router

فرض کنید می‌خواهید یک برنامه ساده با دو صفحه “خانه” و “درباره ما” ایجاد کنید. با استفاده از Vue Router می‌توانید این کار را به سادگی انجام دهید:
فایل router.js

import { createRouter, createWebHistory } from 'vue-router';
import Home from './components/Home.vue';
import About from './components/About.vue';

const routes = [
  { path: '/', component: Home },
  { path: '/about', component: About },
];

const router = createRouter({
  history: createWebHistory(),
  routes,
});

export default router;

فایل App.vue

<template>
  <div>
    <nav>
      <router-link to="/">خانه</router-link>
      <router-link to="/about">درباره ما</router-link>
    </nav>
    <router-view></router-view>
  </div>
</template>

توضیح کد:

router-link: برای ایجاد لینک‌های مسیریابی استفاده می‌شود که به صورت خودکار کلاس‌های CSS لازم را اضافه می‌کند.
router-view: به عنوان مکانی برای نمایش کامپوننت مرتبط با مسیر فعلی عمل می‌کند.

مزایای Vue Router در پروژه‌ها

سادگی در استفاده: پیکربندی و استفاده از Vue Router حتی برای مبتدیان آسان است.
قابلیت گسترش: ویژگی‌های پیشرفته مانند گاردهای مسیریابی و بارگذاری تنبل برای برنامه‌های پیچیده مفید هستند.
یکپارچگی با Vue.js: Vue Router به طور کامل با سایر ویژگی‌ها و ابزارهای Vue.js سازگار است.

Vue Router یک ابزار قدرتمند است که مسیریابی در Vue.js را به تجربه‌ای ساده و لذت‌بخش تبدیل می‌کند. با استفاده از این ابزار، می‌توانید برنامه‌های SPA حرفه‌ای و بهینه‌ای طراحی کنید که نیازهای کاربران و توسعه‌دهندگان را به خوبی برآورده کند.

مسیریابی پویا در Vue.js

مسیریابی پویا زمانی کاربرد دارد که نیاز باشد اطلاعات متغیری مانند شناسه‌ها (ID)، نام‌ها یا سایر پارامترها در URL مسیرها گنجانده شود. این نوع مسیریابی به شما اجازه می‌دهد تا از یک ساختار مسیر برای نمایش صفحات مختلف استفاده کنید، به جای اینکه برای هر صفحه یا داده، مسیر جداگانه‌ای تعریف کنید.

به عنوان مثال، اگر برنامه‌ای برای نمایش اطلاعات کاربران دارید، به جای تعریف مسیرهای ثابت برای هر کاربر، می‌توانید یک مسیر پویا مانند /user/:id ایجاد کنید. در این مسیر، :id به عنوان یک متغیر عمل می‌کند که مقدار آن در زمان اجرا مشخص می‌شود.

مزایای مسیریابی پویا

سادگی و انعطاف‌پذیری: به جای تعریف چندین مسیر برای داده‌های مشابه، می‌توان از یک مسیر پویا استفاده کرد.
مدیریت ساده‌تر داده‌ها: مسیرهای پویا به راحتی با منابع داده (مانند API‌ها) ادغام می‌شوند.
پشتیبانی از پارامترهای متغیر: امکان مدیریت پارامترهای متعدد در URL فراهم می‌شود.

تعریف مسیرهای پویا

برای ایجاد یک مسیر پویا در Vue Router، کافی است در مسیر path از علامت کولون : قبل از نام متغیر استفاده کنید. مثال:

const routes = [
  { path: '/user/:id', component: UserProfile },
];

در اینجا:

مسیر /user/:id تعریف شده است.
مقدار id در زمان اجرا به این مسیر ارسال خواهد شد.
کامپوننت UserProfile نمایش داده می‌شود و می‌تواند به مقدار id دسترسی داشته باشد.

دسترسی به پارامترهای پویا

Vue Router پارامترهای پویا را از طریق شیء this.$route.params در اختیار شما قرار می‌دهد. برای استفاده از این پارامترها، می‌توانید کد زیر را در کامپوننت خود بنویسید:
مثال: دسترسی به id در UserProfile

export default {
  mounted() {
    console.log(this.$route.params.id); // مقدار id نمایش داده می‌شود
  },
};

استفاده در قالب (Template):

<template>
  <div>
    <h1>کاربر شماره: {{ $route.params.id }}</h1>
  </div>
</template>

ارسال پارامترهای پویا به مسیر

پارامترهای پویا می‌توانند از طریق لینک‌ها یا برنامه‌ریزی کدنویسی ارسال شوند:
استفاده از router-link:

<template>
  <router-link :to="'/user/' + userId">مشاهده پروفایل</router-link>
</template>

هدایت برنامه‌ریزی‌شده:

this.$router.push(`/user/${userId}`);

پشتیبانی از چندین پارامتر پویا

اگر نیاز به استفاده از چندین پارامتر پویا دارید، می‌توانید آن‌ها را در مسیر تعریف کنید:

const routes = [
  { path: '/user/:id/:action', component: UserActions },
];

در این مثال، مسیر می‌تواند چیزی شبیه به /user/123/edit باشد که در آن:

id مقدار شناسه کاربر است.
action عملیات خاصی مانند “edit” یا “view” است.

دسترسی به این پارامترها:

mounted() {
  console.log(this.$route.params.id);     // مقدار 123
  console.log(this.$route.params.action); // مقدار edit
}

اعتبارسنجی پارامترهای پویا

در برخی موارد، ممکن است بخواهید مقادیر پارامترها را پیش از نمایش صفحه اعتبارسنجی کنید. این کار با استفاده از گاردهای مسیریابی انجام می‌شود.
مثال: گارد برای بررسی مقدار id

const routes = [
  {
    path: '/user/:id',
    component: UserProfile,
    beforeEnter: (to, from, next) => {
      const id = to.params.id;
      if (!isNaN(id)) {
        next(); // مقدار معتبر است
      } else {
        next('/error'); // به صفحه خطا هدایت شود
      }
    },
  },
];

مسیریابی پویا در Vue.js ابزار قدرتمندی برای ساخت برنامه‌های مقیاس‌پذیر است که نیاز به مدیریت داده‌های متغیر دارند. این قابلیت انعطاف‌پذیری بالایی در تعریف مسیرها فراهم کرده و امکان پیاده‌سازی ویژگی‌هایی مانند پروفایل کاربر، صفحات محصول، و نمایش محتوا بر اساس شناسه یا پارامتر خاص را به‌سادگی فراهم می‌کند.

مسیرهای تو در تو (Nested Routes) در Vue.js

مسیرهای تو در تو (Nested Routes) یکی از ویژگی‌های پیشرفته Vue Router است که امکان مدیریت مسیرهای پیچیده را با ساختاری سلسله‌مراتبی فراهم می‌کند. این ویژگی به شما اجازه می‌دهد بخش‌های مختلف یک برنامه را در دل یکدیگر نمایش دهید، به‌ویژه زمانی که بخش‌هایی از صفحه به صورت تودرتو وابسته به مسیر اصلی باشند.

مزایای استفاده از مسیرهای تو در تو

ساختاردهی بهتر: مسیرهای تو در تو کدهای مسیریابی شما را سازمان‌یافته‌تر می‌کنند.
مدیریت صفحات وابسته: برای صفحاتی که دارای بخش‌های فرعی (subsections) هستند، مسیرهای تو در تو ابزار مناسبی هستند.
سهولت در استفاده از کامپوننت‌های مشترک: می‌توانید کامپوننت‌های والد و فرزند را به‌راحتی در کنار یکدیگر استفاده کنید.
قابلیت تعویض بخش‌ها: کاربران می‌توانند در یک بخش از صفحه بدون تغییر مسیر اصلی جابه‌جا شوند.

تعریف مسیرهای تو در تو

برای تعریف مسیرهای تو در تو، از خاصیت children در تنظیمات هر مسیر استفاده می‌شود. مسیرهای فرزند درون خاصیت children مسیر والد قرار می‌گیرند.
مثال پایه‌ای:

فرض کنید برنامه شما شامل یک صفحه کاربر است که دو بخش “پروفایل” و “تنظیمات” دارد.

const routes = [
  {
    path: '/user',
    component: User, // کامپوننت والد
    children: [
      { path: 'profile', component: UserProfile }, // مسیر فرزند
      { path: 'settings', component: UserSettings }, // مسیر فرزند
    ],
  },
];

در این مثال:

مسیر /user کامپوننت User را نمایش می‌دهد.
مسیر /user/profile کامپوننت UserProfile را به عنوان فرزند نمایش می‌دهد.
مسیر /user/settings کامپوننت UserSettings را نمایش می‌دهد.

نمایش کامپوننت‌های فرزند

برای نمایش کامپوننت‌های فرزند در کامپوننت والد، باید از عنصر ویژه router-view استفاده کنید.
نمونه کامپوننت والد:

<template>
  <div>
    <h1>صفحه کاربر</h1>
    <nav>
      <router-link to="/user/profile">پروفایل</router-link>
      <router-link to="/user/settings">تنظیمات</router-link>
    </nav>
    <!-- اینجا کامپوننت‌های فرزند نمایش داده می‌شوند -->
    <router-view></router-view>
  </div>
</template>

در این کد:

لینک‌ها به مسیرهای فرزند هدایت می‌شوند.
router-view محل نمایش کامپوننت‌های فرزند است.

دسترسی به مسیرهای فرزند

مسیرهای فرزند می‌توانند به صورت نسبی تعریف شوند. به عنوان مثال، مسیر profile در مسیر والد /user به صورت خودکار /user/profile خواهد شد.
مسیر نسبی

children: [
  { path: 'profile', component: UserProfile }, // /user/profile
  { path: 'settings', component: UserSettings }, // /user/settings
]

مسیر مطلق

در صورت نیاز، می‌توانید مسیرهای مطلق تعریف کنید، اما معمولاً توصیه نمی‌شود، زیرا ساختار سلسله‌مراتبی را نقض می‌کند.

children: [
  { path: '/profile', component: UserProfile }, // مسیر مطلق
]

گاردهای مسیریابی در مسیرهای تو در تو

شما می‌توانید گاردهای مسیریابی را هم برای مسیرهای والد و هم برای مسیرهای فرزند اعمال کنید. اگر گاردی روی مسیر والد اعمال شود، قبل از مسیریابی به هر یک از مسیرهای فرزند اجرا خواهد شد.

const routes = [
  {
    path: '/user',
    component: User,
    beforeEnter: (to, from, next) => {
      console.log('گارد مسیر والد');
      next();
    },
    children: [
      { path: 'profile', component: UserProfile },
      { path: 'settings', component: UserSettings },
    ],
  },
];

بارگذاری تنبل مسیرهای تو در تو

برای بهبود عملکرد، می‌توانید کامپوننت‌های فرزند را به صورت پویا (Lazy Load) بارگذاری کنید:

const routes = [
  {
    path: '/user',
    component: () => import('./components/User.vue'),
    children: [
      { path: 'profile', component: () => import('./components/UserProfile.vue') },
      { path: 'settings', component: () => import('./components/UserSettings.vue') },
    ],
  },
];

مسیرهای تو در تو (Nested Routes) ابزاری حیاتی برای ساخت برنامه‌های پیچیده و چندبخشی هستند. با استفاده از این ویژگی:

می‌توانید ساختاری منظم و قابل‌مدیریت برای مسیریابی برنامه خود ایجاد کنید.
نمایش بخش‌های مختلف برنامه به شکل سلسله‌مراتبی ساده‌تر می‌شود.
تجربه کاربری روان و حرفه‌ای برای کاربران فراهم می‌گردد.

با درک و استفاده صحیح از مسیرهای تو در تو، می‌توانید برنامه‌های Vue.js را به سطح بالاتری از کارایی و قابلیت گسترش برسانید.

گاردهای مسیریابی (Navigation Guards) در Vue.js

گاردهای مسیریابی قابلیتی هستند که Vue Router برای کنترل دسترسی کاربران به مسیرهای مختلف فراهم می‌کند. این گاردها به شما اجازه می‌دهند قبل از ورود، حین ورود، یا حتی پس از ترک یک مسیر خاص، عملیات خاصی را اجرا کنید.

کاربرد گاردهای مسیریابی

گاردها در شرایط زیر بسیار مفید هستند:

احراز هویت (Authentication): بررسی کنید که آیا کاربر مجاز به دسترسی به مسیر خاصی هست یا خیر.
محدودیت دسترسی: مسیرهایی را فقط برای کاربران خاص، مانند مدیران (Admins)، باز کنید.
بارگذاری داده‌ها: داده‌های لازم برای یک صفحه را قبل از نمایش آن بارگذاری کنید.
اعتبارسنجی (Validation): مطمئن شوید که اطلاعات یا پارامترهای لازم برای یک مسیر معتبر هستند.

انواع گاردهای مسیریابی

Vue Router سه نوع گارد اصلی ارائه می‌دهد:
1. گاردهای سراسری (Global Guards):

این گاردها برای همه مسیرها اعمال می‌شوند و می‌توانند قبل از مسیریابی (beforeEach)، بعد از مسیریابی (afterEach)، یا در حین تغییر مسیر (beforeResolve) اجرا شوند.
2. گاردهای محلی (Per-Route Guards):

این گاردها در زمان تعریف مسیر و به صورت خاص برای هر مسیر مشخص می‌شوند.
3. گاردهای داخل کامپوننت (In-Component Guards):

این گاردها در داخل یک کامپوننت تعریف شده و مربوط به همان کامپوننت هستند.

گاردهای سراسری

گاردهای سراسری را می‌توانید در فایل مربوط به پیکربندی Vue Router، مانند router.js، تعریف کنید.
مثال: گارد سراسری برای احراز هویت

router.beforeEach((to, from, next) => {
  if (to.path === '/admin' && !isAuthenticated()) {
    // اگر کاربر احراز هویت نشده باشد، به صفحه ورود هدایت می‌شود
    next('/login');
  } else {
    // اجازه مسیریابی
    next();
  }
});

جزئیات:

to: مسیر مقصد.
from: مسیر مبدأ.
next: تابعی برای ادامه یا لغو مسیریابی.

گاردهای محلی (Per-Route Guards)

این گاردها به صورت مستقیم در تعریف یک مسیر اعمال می‌شوند:
مثال: گارد محلی برای محدودیت دسترسی

const routes = [
  {
    path: '/admin',
    component: AdminPage,
    beforeEnter: (to, from, next) => {
      if (!isAuthenticated()) {
        next('/login');
      } else {
        next();
      }
    },
  },
];

ویژگی‌ها:

فقط برای مسیر مشخص شده اجرا می‌شود.
مشابه گاردهای سراسری است، اما محدود به یک مسیر خاص است.

گاردهای داخل کامپوننت

اگر نیاز دارید گاردها را مستقیماً در کامپوننت مدیریت کنید، می‌توانید از گاردهای زیر استفاده کنید:

beforeRouteEnter
قبل از ورود به کامپوننت اجرا می‌شود.
دسترسی به this وجود ندارد زیرا کامپوننت هنوز ایجاد نشده است.

مثال: بارگذاری داده‌ها

export default {
  beforeRouteEnter(to, from, next) {
    // بارگذاری داده‌ها قبل از نمایش کامپوننت
    fetchData(to.params.id).then(data => {
      next(vm => {
        vm.data = data; // تخصیص داده‌ها به کامپوننت
      });
    });
  },
};

beforeRouteUpdate
هنگام تغییر پارامترهای مسیر (بدون ترک کامپوننت) اجرا می‌شود.

مثال: واکنش به تغییر پارامتر

export default {
  beforeRouteUpdate(to, from, next) {
    this.fetchData(to.params.id);
    next();
  },
};

beforeRouteLeave
قبل از ترک کامپوننت اجرا می‌شود.

مثال: هشدار قبل از ترک صفحه

export default {
  beforeRouteLeave(to, from, next) {
    if (this.hasUnsavedChanges) {
      const answer = window.confirm('تغییرات ذخیره نشده‌اند. ادامه می‌دهید؟');
      if (!answer) next(false);
      else next();
    } else {
      next();
    }
  },
};

 

اجرای زنجیره‌ای گاردها

اگر گاردهای سراسری، محلی، و داخل کامپوننت به صورت هم‌زمان تعریف شوند، ترتیب اجرای آن‌ها به شکل زیر خواهد بود:

گاردهای سراسری beforeEach
گاردهای محلی beforeEnter
گاردهای داخل کامپوننت (beforeRouteEnter)
گاردهای سراسری beforeResolve
مسیریابی انجام می‌شود
گاردهای سراسری afterEach

گاردهای مسیریابی (Navigation Guards) ابزار قدرتمندی برای کنترل و مدیریت جریان کاربری در برنامه‌های Vue.js هستند. این گاردها برای اطمینان از امنیت، دسترسی محدود، و تجربه کاربری بهتر طراحی شده‌اند. با استفاده از این قابلیت‌ها می‌توانید مسیریابی برنامه خود را بهینه و مطابق با نیازهای خاص پروژه خود پیاده‌سازی کنید.

بارگذاری تنبل (Lazy Loading) در Vue.js

بارگذاری تنبل (Lazy Loading) یکی از تکنیک‌های بهینه‌سازی در برنامه‌های وب تک‌صفحه‌ای (SPA) است که به شما اجازه می‌دهد فایل‌های مربوط به کامپوننت‌ها فقط در زمان نیاز بارگذاری شوند. این روش باعث کاهش زمان بارگذاری اولیه (initial load time) و بهبود تجربه کاربری، به خصوص در پروژه‌های بزرگ، می‌شود.

چرا بارگذاری تنبل مهم است؟

کاهش حجم فایل‌های اولیه: در برنامه‌های بزرگ، بارگذاری همه کامپوننت‌ها به صورت پیش‌فرض می‌تواند باعث افزایش حجم فایل جاوااسکریپت شود. Lazy Loading این مشکل را برطرف می‌کند.
بهبود زمان بارگذاری اولیه: تنها کدهای موردنیاز برای نمایش صفحه اصلی بارگذاری می‌شوند و فایل‌های دیگر بعداً بارگذاری خواهند شد.
افزایش کارایی برنامه: استفاده از بارگذاری تنبل منابع سیستم را بهتر مدیریت می‌کند، زیرا فایل‌ها فقط زمانی که لازم باشند بارگذاری می‌شوند.
بهبود تجربه کاربری: به دلیل کاهش زمان انتظار اولیه، کاربران تجربه‌ای سریع‌تر و روان‌تر خواهند داشت.

پیاده‌سازی بارگذاری تنبل در Vue.js

Vue Router با استفاده از تابع import() قابلیت بارگذاری تنبل را به سادگی فراهم می‌کند.
مثال ساده:

const routes = [
  {
    path: '/about',
    component: () => import('./components/About.vue'), // بارگذاری تنبل
  },
];

در اینجا:

کامپوننت About تنها زمانی بارگذاری می‌شود که کاربر به مسیر /about مراجعه کند.
تابع import() یک پرومیس (Promise) برمی‌گرداند که فایل مربوطه را به صورت پویا بارگذاری می‌کند.

بارگذاری تنبل در مسیرهای تو در تو

بارگذاری تنبل به‌راحتی در مسیرهای تو در تو (Nested Routes) نیز قابل استفاده است.
مثال:

const routes = [
  {
    path: '/user',
    component: () => import('./components/User.vue'),
    children: [
      {
        path: 'profile',
        component: () => import('./components/UserProfile.vue'), // بارگذاری تنبل
      },
      {
        path: 'settings',
        component: () => import('./components/UserSettings.vue'), // بارگذاری تنبل
      },
    ],
  },
];

در این مثال:

فایل‌های UserProfile و UserSettings فقط در صورت نیاز بارگذاری می‌شوند.
این روش به بهینه‌سازی برنامه‌های پیچیده و چندلایه کمک می‌کند.

تقسیم‌بندی باندل‌ها (Code Splitting)

Vue.js و Webpack به صورت خودکار فایل‌های بارگذاری‌شده به صورت Lazy Load را در باندل‌های جداگانه (chunk) قرار می‌دهند.
تنظیم نام باندل برای خوانایی بهتر:

می‌توانید نام باندل‌های Lazy Load را برای مدیریت بهتر تعیین کنید:

const routes = [
  {
    path: '/about',
    component: () => import(/* webpackChunkName: "about" */ './components/About.vue'),
  },
];

در این مثال، فایل تولیدشده در Webpack نامی مشابه about.[hash].js خواهد داشت.

نمایش یک صفحه بارگذاری (Loading Page)

هنگام بارگذاری تنبل، ممکن است کاربران در انتظار بارگذاری فایل بمانند. می‌توانید با نمایش یک کامپوننت یا پیام بارگذاری، تجربه کاربری را بهبود ببخشید.
استفاده از async component:

const About = () => ({
  component: import('./components/About.vue'), // بارگذاری تنبل
  loading: LoadingComponent, // کامپوننت نمایش داده‌شده در زمان بارگذاری
  error: ErrorComponent, // کامپوننت نمایش داده‌شده در صورت بروز خطا
  delay: 200, // تأخیر پیش از نمایش کامپوننت بارگذاری
  timeout: 3000, // زمان نهایی پیش از نمایش خطا
});

سپس از این کامپوننت در مسیرها استفاده کنید:

const routes = [
  {
    path: '/about',
    component: About,
  },
];

بارگذاری تنبل در پروژه‌های بزرگ

برای پروژه‌های بزرگ، بهتر است کامپوننت‌های مرتبط با هر ماژول یا بخش را در فایل‌های جداگانه قرار دهید و سپس آن‌ها را به صورت Lazy Load بارگذاری کنید.
مثال: بارگذاری ماژول‌ها

const routes = [
  {
    path: '/dashboard',
    component: () => import('./modules/dashboard/DashboardModule.vue'),
  },
  {
    path: '/reports',
    component: () => import('./modules/reports/ReportsModule.vue'),
  },
];

بارگذاری تنبل (Lazy Loading) یک روش استاندارد برای بهینه‌سازی برنامه‌های Vue.js است. این ویژگی:

حجم فایل‌های اولیه را کاهش می‌دهد.
زمان بارگذاری برنامه را بهبود می‌بخشد.
عملکرد و تجربه کاربری را ارتقا می‌دهد.

با درک و پیاده‌سازی صحیح Lazy Loading، می‌توانید برنامه‌های Vue.js خود را سریع‌تر، سبک‌تر و کارآمدتر کنید.

مسیریابی برنامه‌ریزی‌شده در Vue.js

مسیریابی برنامه‌ریزی‌شده (Programmatic Navigation) به شما این امکان را می‌دهد که به صورت دستی و با استفاده از کدنویسی، کاربر را به مسیر دیگری هدایت کنید. برخلاف مسیریابی معمول که با کلیک روی لینک‌ها انجام می‌شود، در این روش می‌توانید مسیریابی را به صورت دینامیک و در پاسخ به شرایط خاص (مانند کلیک روی یک دکمه، تأیید فرم، یا تغییر وضعیت) انجام دهید.

چرا مسیریابی برنامه‌ریزی‌شده مفید است؟

مدیریت پویا: در مواردی که نیاز به تغییر مسیر بر اساس وضعیت برنامه یا ورودی کاربر دارید، این روش بسیار کاربردی است.
هدایت پس از عملیات: پس از تکمیل فرم، لاگین موفق، یا ثبت سفارش، می‌توانید کاربر را به صفحه مناسب هدایت کنید.
کنترل بیشتر: این روش امکان پیاده‌سازی منطق پیچیده‌تر در مسیریابی را فراهم می‌کند.

استفاده از this.$router.push()

Vue Router متدهایی مانند push و replace را ارائه می‌دهد که برای مسیریابی برنامه‌ریزی‌شده استفاده می‌شوند.
مثال ساده:

هدایت به مسیر /home با استفاده از push:

this.$router.push('/home');

ارسال پارامترها:

می‌توانید پارامترها را هنگام مسیریابی ارسال کنید.

this.$router.push({ path: '/user', query: { id: 123 } });

در اینجا، آدرس تولیدشده به صورت /user?id=123 خواهد بود.
استفاده با نام مسیر:

اگر مسیرها نام‌گذاری شده باشند، می‌توانید از خاصیت name استفاده کنید:

this.$router.push({ name: 'UserProfile', params: { userId: 123 } });

 

استفاده از this.$router.replace()

متد replace مشابه push عمل می‌کند، با این تفاوت که مسیر جدید را جایگزین مسیر فعلی در تاریخچه مرورگر می‌کند.

تفاوت push و replace:

push: مسیر جدید به تاریخچه اضافه می‌شود و کاربر می‌تواند با دکمه بازگشت مرورگر به مسیر قبلی بازگردد.
replace: مسیر جدید جایگزین مسیر قبلی می‌شود و امکان بازگشت وجود ندارد.

مثال:

this.$router.replace('/login');

استفاده از go() برای حرکت در تاریخچه

متد go() به شما اجازه می‌دهد بین مسیرهای موجود در تاریخچه مرورگر حرکت کنید.
مثال:

حرکت به مسیر قبلی:

this.$router.go(-1);

حرکت به مسیر بعدی:

this.$router.go(1);

ترکیب با شرایط پویا

مسیریابی برنامه‌ریزی‌شده معمولاً با منطق شرطی ترکیب می‌شود:
مثال: هدایت پس از لاگین موفق

if (isAuthenticated()) {
  this.$router.push('/dashboard');
} else {
  this.$router.push('/login');
}

انتقال داده‌ها هنگام مسیریابی

اگر بخواهید داده‌هایی را هنگام مسیریابی ارسال کنید، می‌توانید از خاصیت state استفاده کنید.
مثال: ارسال داده با push

this.$router.push({
  path: '/details',
  state: { productId: 42 },
});

دریافت داده‌های ارسال‌شده:

در کامپوننت مقصد، داده‌ها از this.$route.state قابل دسترسی هستند:

export default {
  mounted() {
    console.log(this.$route.state.productId); // 42
  },
};

کاربرد در ترکیب با رویدادها

مسیریابی برنامه‌ریزی‌شده به‌خوبی با رویدادهایی مانند کلیک روی دکمه‌ها و ارسال فرم‌ها ترکیب می‌شود.
مثال: هدایت در پاسخ به کلیک

<template>
  <button @click="goToProfile">مشاهده پروفایل</button>
</template>

<script>
export default {
  methods: {
    goToProfile() {
      this.$router.push({ name: 'UserProfile', params: { userId: 123 } });
    },
  },
};
</script>

مسیریابی برنامه‌ریزی‌شده (Programmatic Navigation) ابزار قدرتمندی است که در کنار مسیریابی معمول، امکان مدیریت پویا و منعطف جریان کاربری در برنامه‌های Vue.js را فراهم می‌کند. با استفاده از متدهایی مانند push, replace, و go می‌توانید مسیریابی را به سادگی کنترل کرده و تجربه کاربری بهتری ارائه دهید.

نتیجه‌گیری

مسیریابی (Routing) یکی از مهم‌ترین جنبه‌های توسعه برنامه‌های وب تک‌صفحه‌ای (SPA) است. در Vue.js، Vue Router به عنوان کتابخانه‌ای قدرتمند، تمامی امکانات لازم برای مدیریت مسیرها، نمایش کامپوننت‌های مرتبط، و هدایت کاربران بین بخش‌های مختلف برنامه را فراهم می‌کند.

در این مقاله، از مبانی مسیریابی گرفته تا موضوعات پیشرفته‌تری مانند مسیریابی پویا، مسیرهای تو در تو، گاردهای مسیریابی، بارگذاری تنبل، و مسیریابی برنامه‌ریزی‌شده بررسی شد. هر یک از این مفاهیم ابزارهایی را در اختیار شما قرار می‌دهند تا تجربه کاربری بهتری ایجاد کرده و برنامه‌هایی کارآمدتر و ساختارمندتر توسعه دهید.

به‌ویژه، مفاهیمی مانند بارگذاری تنبل (Lazy Loading) و گاردهای مسیریابی (Navigation Guards) نقش کلیدی در بهینه‌سازی عملکرد و افزایش امنیت برنامه‌های Vue.js دارند. با ترکیب این تکنیک‌ها می‌توانید برنامه‌هایی سریع‌تر، ایمن‌تر و کاربرپسندتر بسازید.

اگرچه این مقاله راهنمای جامعی برای مسیریابی در Vue.js ارائه کرد، یادگیری و تسلط بیشتر به تمرین و کاوش در مستندات رسمی و پروژه‌های عملی نیاز دارد. در ادامه منابع بیشتری برای مطالعه معرفی شده‌اند که می‌توانند به شما در مسیر یادگیری کمک کنند.

با درک عمیق‌تر مفاهیم مسیریابی، قادر خواهید بود برنامه‌های Vue.js حرفه‌ای‌تری طراحی کنید و تجربه‌ای بی‌نقص برای کاربران خود فراهم آورید.

آموزش مسیریابی (Routing) Vue.js

دیدگاه های شما

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *