ناوبری و لینک‌دهی در Next.js – رندر سمت سرور، پیش‌بارگذاری، و تجربه کاربری سریع

Next.js با استفاده از رندر سمت سرور، پیش‌بارگذاری خودکار، و انتقال‌های سمت کلاینت، تجربه‌ای سریع و روان برای ناوبری بین صفحات فراهم می‌کند. در این مقاله، با مفاهیم کلیدی مانند prefetching، streaming، و فایل loading.tsx آشنا می‌شویم و یاد می‌گیریم چگونه ناوبری را برای مسیرهای پویا و شبکه‌های کند بهینه کنیم.

Next.js navigationprefetchingstreamingloading.tsx

~3 دقیقه مطالعه • بروزرسانی ۳ آبان ۱۴۰۴

مقدمه


در Next.js، مسیرها به‌صورت پیش‌فرض روی سرور رندر می‌شوند. این بدان معناست که کاربر باید منتظر پاسخ سرور بماند تا مسیر جدید نمایش داده شود. برای بهبود این تجربه، Next.js از تکنیک‌هایی مانند پیش‌بارگذاری (Prefetching)، Streaming، و انتقال سمت کلاینت استفاده می‌کند.


رندر سمت سرور


در Next.js، فایل‌های layout.tsx و page.tsx به‌صورت پیش‌فرض کامپوننت‌های سروری هستند. دو نوع رندر سمت سرور وجود دارد:


  • رندر ایستا (Static Rendering): در زمان build یا revalidation انجام می‌شود و نتیجه کش می‌شود.
  • رندر پویا (Dynamic Rendering): در زمان درخواست کاربر انجام می‌شود.

چالش این روش، تأخیر در نمایش مسیر جدید است. برای حل این مشکل، Next.js از پیش‌بارگذاری و انتقال سمت کلاینت استفاده می‌کند.


پیش‌بارگذاری (Prefetching)


پیش‌بارگذاری یعنی بارگذاری مسیرها در پس‌زمینه قبل از کلیک کاربر. Next.js به‌صورت خودکار مسیرهایی را که با <Link> مشخص شده‌اند، هنگام ورود به viewport یا hover شدن، پیش‌بارگذاری می‌کند:


// app/layout.tsx
import Link from 'next/link';

export default function Layout({ children }) {
  return (
    <html>
      <body>
        <nav>
          <Link href="/blog">Blog</Link> {/* پیش‌بارگذاری می‌شود */}
          <a href="/contact">Contact</a> {/* پیش‌بارگذاری نمی‌شود */}
        </nav>
        {children}
      </body>
    </html>
  );
}

میزان پیش‌بارگذاری به نوع مسیر بستگی دارد:

  • مسیر ایستا: به‌طور کامل پیش‌بارگذاری می‌شود.
  • مسیر پویا: پیش‌بارگذاری نمی‌شود یا فقط بخشی از آن (مانند لایه‌ها یا loading) بارگذاری می‌شود.

Streaming


Streaming به سرور اجازه می‌دهد بخش‌هایی از مسیر را به‌محض آماده شدن ارسال کند، بدون اینکه منتظر رندر کامل بماند. این باعث می‌شود کاربر سریع‌تر بازخورد بصری دریافت کند.


برای فعال‌سازی Streaming، کافی است فایل loading.tsx را در پوشه مسیر قرار دهید:


// app/dashboard/loading.tsx
export default function Loading() {
  return <LoadingSkeleton />;
}

Next.js به‌صورت خودکار محتوای page.tsx را درون <Suspense> قرار می‌دهد و ابتدا UI موقتی را نمایش می‌دهد تا محتوای اصلی آماده شود.


مزایای استفاده از loading.tsx


  • ناوبری سریع و بازخورد فوری برای کاربر
  • لایه‌های مشترک فعال باقی می‌مانند
  • بهبود Core Web Vitals مانند TTFB، FCP و TTI

جمع‌بندی


Next.js با ترکیب رندر سمت سرور، پیش‌بارگذاری هوشمند، و Streaming، تجربه ناوبری را بهینه می‌کند. با استفاده از <Link> برای لینک‌دهی، loading.tsx برای skeleton UI، و ساختار مناسب مسیرها، می‌توان اپلیکیشنی سریع، پاسخ‌گو و کاربرپسند ساخت.


نوشته و پژوهش شده توسط دکتر شاهین صیامی