Nextjs

وضعیت ثبت نامی جدید : ثبت نام باز می باشد
تعداد ظرفیت ثبت نام : 200 نفر

Next.js یکی از محبوب‌ترین فریمورک‌های جاوا اسکریپت برای توسعه وب‌سایت‌ها و اپلیکیشن‌های مدرن است. این فریمورک به شما امکان می‌دهد تا با استفاده از قابلیت‌های رندر سمت سرور (SSR)، داده‌های استاتیک، و روتینگ داینامیک، برنامه‌هایی کارآمد و سریع بسازید. در این دوره آموزشی 20 سطحی، شما به طور گام به گام با تمام جنبه‌های Next.js از مفاهیم پایه تا معماری‌های پیچیده آشنا می‌شوید. هر سطح برای توسعه مهارت‌های شما در کار با Next.js طراحی شده است و شما را از ساخت پروژه‌های ساده به سمت مدیریت تیم‌های توسعه حرفه‌ای هدایت می‌کند.

 

سطح 1: آشنایی با مفاهیم پایه

  • آشنایی با React و مفاهیم پایه جاوا اسکریپت
  • نصب و پیکربندی اولیه محیط توسعه (Node.js و npm)
  • نصب و راه‌اندازی Next.js
  • ساخت یک پروژه ساده با Next.js
  • درک ساختار پوشه‌ها در Next.js
  • ایجاد اولین صفحه با Next.js
  • معرفی hot reloading و نحوه استفاده از آن
  • آشنایی با مفهوم SSR (Server-Side Rendering)
  • استفاده از Link و ناوبری بین صفحات
  • بررسی تفاوت بین SSR و CSR (Client-Side Rendering)

سطح 2: کامپوننت‌ها و روتینگ

  • ایجاد و استفاده از کامپوننت‌ها در Next.js
  • آشنایی با روتینگ داخلی Next.js
  • ایجاد صفحات داینامیک با استفاده از Dynamic Routes
  • مدیریت مسیرها با استفاده از Link و useRouter
  • معرفی فایل _app.js برای کامپوننت‌های گلوبال
  • معرفی فایل _document.js برای تنظیمات HTML گلوبال
  • استفاده از متغیرهای محیطی در Next.js
  • مدیریت کامپوننت‌های گلوبال مانند Header و Footer
  • پیاده‌سازی صفحات 404 و مدیریت خطا
  • معرفی روش‌های مختلف مدیریت مسیرها

سطح 3: استایل‌دهی کامپوننت‌ها

  • معرفی روش‌های مختلف استایل‌دهی در Next.js
  • استفاده از CSS-in-JS برای استایل‌دهی کامپوننت‌ها
  • معرفی و استفاده از Styled Components
  • آشنایی با CSS Modules برای مدیریت استایل‌ها
  • استفاده از Sass و LESS برای استایل‌دهی پیشرفته
  • پیاده‌سازی استایل‌های گلوبال و محلی
  • استفاده از ابزارهای مانند Tailwind CSS
  • مدیریت استایل‌ها برای کامپوننت‌های مستقل
  • پیاده‌سازی تم‌های مختلف در پروژه‌های Next.js
  • بهینه‌سازی استایل‌ها برای بهبود عملکرد

سطح 4: API Routes و ارتباط با بک‌اند

  • آشنایی با API Routes در Next.js
  • ایجاد اولین API ساده با Next.js
  • استفاده از getServerSideProps برای مدیریت درخواست‌ها
  • پیاده‌سازی عملیات CRUD در API Routes
  • ارسال و دریافت داده‌ها از سمت سرور
  • مدیریت امنیت و احراز هویت در API‌ها
  • استفاده از کتابخانه‌های خارجی برای تعامل با API
  • پیاده‌سازی روش‌های async/await برای درخواست‌ها
  • تست و دیباگ کردن API Routes
  • استفاده از Postman برای تست API‌ها

سطح 5: استقرار اپلیکیشن‌های Next.js

  • آشنایی با پلتفرم‌های استقرار مانند Vercel و Netlify
  • استقرار اولین پروژه ساده با استفاده از Vercel
  • بررسی و رفع خطاهای استقرار
  • بهینه‌سازی پروژه برای محیط تولید
  • استفاده از ابزارهای CI/CD برای استقرار خودکار
  • مدیریت محیط‌های مختلف (Development, Staging, Production)
  • بررسی تنظیمات مربوط به استقرار در Next.js
  • پیاده‌سازی کدهای Production-ready
  • استفاده از GitHub Actions برای اتومات‌سازی استقرار
  • تنظیم محیط‌های مختلف برای مدیریت نسخه‌ها

سطح 6: فچینگ داده‌ها و مدیریت محتوا

  • استفاده از getStaticProps برای دریافت داده‌ها به صورت استاتیک
  • استفاده از getServerSideProps برای دریافت داده‌ها به صورت داینامیک
  • استفاده از getInitialProps برای فچینگ داده‌ها قبل از بارگذاری صفحه
  • فچینگ داده‌ها از API‌های خارجی
  • مدیریت داده‌های استاتیک و داینامیک
  • استفاده از SWR برای فچینگ داده‌های سمت کلاینت
  • پیاده‌سازی caching برای بهبود کارایی
  • مدیریت منابع خارجی و API‌ها در فچینگ داده‌ها
  • بهینه‌سازی درخواست‌های HTTP برای کاهش زمان بارگذاری
  • استفاده از Incremental Static Regeneration برای آپدیت‌های سریع

سطح 7: ساخت فروشگاه‌های کوچک و مدیریت State

  • استفاده از Redux برای مدیریت وضعیت اپلیکیشن
  • استفاده از Zustand به عنوان جایگزین سبک‌تر برای Redux
  • ایجاد فروشگاه‌های آنلاین کوچک با Next.js
  • پیاده‌سازی سبد خرید با Redux
  • استفاده از local storage برای ذخیره‌سازی اطلاعات موقت
  • مدیریت محصولات و پرداخت‌ها در فروشگاه آنلاین
  • پیاده‌سازی حالت‌های مختلف برای مدیریت State
  • استفاده از Context API برای مدیریت وضعیت محلی
  • پیاده‌سازی حالت‌های جهانی و محلی در پروژه
  • استفاده از Redux DevTools برای دیباگ و مدیریت وضعیت

سطح 8: بهینه‌سازی عملکرد اپلیکیشن

  • استفاده از Code Splitting برای بهبود سرعت بارگذاری
  • استفاده از lazy loading برای بهینه‌سازی تصاویر و منابع
  • پیاده‌سازی بهینه‌سازی تصاویر با next/image
  • کاهش حجم فایل‌های جاوا اسکریپت و CSS
  • استفاده از ابزارهایی مانند Lighthouse برای تحلیل عملکرد
  • بهینه‌سازی عملکرد رندرینگ سمت سرور
  • مدیریت caching و ذخیره‌سازی داده‌ها برای بهبود کارایی
  • بررسی و رفع bottleneck‌های مرتبط با عملکرد
  • پیاده‌سازی PWA برای بهبود عملکرد در موبایل
  • استفاده از Webpack و Babel برای بهینه‌سازی build

سطح 9: استفاده از TypeScript در Next.js

  • پیاده‌سازی پروژه‌های TypeScript در Next.js
  • نصب و راه‌اندازی TypeScript در پروژه
  • تبدیل پروژه‌های جاوا اسکریپتی به TypeScript
  • استفاده از interface و types در TypeScript
  • مدیریت props و state با TypeScript
  • استفاده از Generics برای کنترل بهتر داده‌ها
  • رفع مشکلات typing و دیباگ کدهای TypeScript
  • استفاده از کتابخانه‌های خارجی با TypeScript
  • پیاده‌سازی type-safe API در Next.js
  • استفاده از TypeScript برای فچینگ داده‌ها

سطح 10: پیاده‌سازی اپلیکیشن‌های چندزبانه

  • استفاده از کتابخانه next-i18next برای پیاده‌سازی چندزبانه
  • مدیریت محتوای چندزبانه در پروژه‌های Next.js
  • پیاده‌سازی فایل‌های ترجمه و تنظیمات زبان‌ها
  • ایجاد مسیرهای خاص برای زبان‌های مختلف
  • مدیریت و کنترل تغییرات زبان در زمان اجرا
  • تنظیمات SEO برای اپلیکیشن‌های چندزبانه
  • پیاده‌سازی تجربه کاربری مناسب برای زبان‌های مختلف
  • مدیریت راست‌به‌چپ (RTL) در طراحی رابط کاربری
  • استفاده از ابزارهای مدیریت زبان و ترجمه
  • بهینه‌سازی ترجمه‌ها و محتوای چندزبانه برای کاربران

سطح 11: ساختاردهی پروژه‌های بزرگ با Design Systems

  • پیاده‌سازی Design Systems برای پروژه‌های بزرگ
  • استفاده از Storybook برای مدیریت کامپوننت‌ها
  • ایجاد سیستم‌های طراحی مقیاس‌پذیر
  • پیاده‌سازی Atomic Design برای مدیریت کامپوننت‌ها
  • استفاده از Design Tokens برای یکپارچه‌سازی طراحی
  • مدیریت رنگ‌ها، تایپوگرافی و استایل‌های گلوبال
  • مستندسازی کامپوننت‌ها و سیستم‌های طراحی
  • کنترل تغییرات و بهبود سیستم‌های طراحی
  • بهینه‌سازی تجربه کاربری با استفاده از سیستم‌های طراحی
  • پیاده‌سازی کامپوننت‌های UI سفارشی با Design Systems

سطح 12: استفاده از Serverless Functions در Next.js

  • ایجاد توابع سرورلس با استفاده از API Routes
  • استفاده از Vercel برای پیاده‌سازی Serverless Functions
  • مدیریت منابع و درخواست‌ها در توابع سرورلس
  • پیاده‌سازی عملیات‌های پردازشی با Serverless Functions
  • استفاده از توابع سرورلس برای انجام عملیات‌های real-time
  • پیاده‌سازی پرداخت‌ها و ذخیره‌سازی داده‌ها با توابع سرورلس
  • استفاده از توابع سرورلس برای مدیریت درخواست‌های API
  • پیاده‌سازی سیستم‌های مقیاس‌پذیر با Serverless
  • بررسی و رفع مشکلات مربوط به Serverless Functions
  • استفاده از ابزارهای مختلف برای تست و دیباگ توابع سرورلس

سطح 13: پیاده‌سازی احراز هویت و مجوزدهی

  • استفاده از JWT برای پیاده‌سازی احراز هویت
  • پیاده‌سازی OAuth2 برای ورود کاربران
  • مدیریت session‌ها و token‌ها برای احراز هویت
  • پیاده‌سازی سیستم‌های ورود چند مرحله‌ای (2FA)
  • استفاده از Passport.js برای احراز هویت
  • پیاده‌سازی social login در اپلیکیشن‌های Next.js
  • مدیریت نقش‌ها و مجوزدهی برای کاربران مختلف
  • پیاده‌سازی سیاست‌های امنیتی برای حفاظت از داده‌ها
  • کنترل دسترسی به صفحات و بخش‌های مختلف اپلیکیشن
  • مدیریت expiration و refresh token‌ها در سیستم‌های احراز هویت

سطح 14: ابزارهای تست و تضمین کیفیت کد

  • استفاده از Jest برای نوشتن تست‌های واحد
  • استفاده از React Testing Library برای تست کامپوننت‌ها
  • نوشتن تست‌های انتگرال برای ارتباطات کامپوننت‌ها
  • تست API Routes با استفاده از Supertest
  • شبیه‌سازی درخواست‌های HTTP در تست
  • مدیریت coverage تست‌ها با Jest
  • نوشتن تست‌های async و promise-based
  • استفاده از Cypress برای تست‌های end-to-end
  • پیاده‌سازی تست‌های امنیتی و عملکردی
  • استفاده از ابزارهای CI/CD برای اجرای خودکار تست‌ها

سطح 15: استقرار اپلیکیشن در محیط‌های مختلف

  • استقرار اپلیکیشن‌های Next.js در Vercel
  • استفاده از Netlify برای دیپلوی پروژه‌ها
  • مدیریت سرورهای VPS و سرورهای اختصاصی برای Next.js
  • استفاده از AWS برای استقرار پروژه‌های مقیاس‌پذیر
  • پیاده‌سازی CI/CD برای اتوماسیون فرآیند استقرار
  • استفاده از Docker برای بسته‌بندی اپلیکیشن‌ها
  • مدیریت استقرار اپلیکیشن‌های Next.js در محیط‌های مختلف
  • مدیریت نسخه‌های مختلف پروژه در محیط‌های گوناگون
  • بررسی و رفع مشکلات استقرار با ابزارهای دیباگ
  • استفاده از ابزارهای مانیتورینگ مانند PM2 برای مدیریت عملکرد

سطح 16: توسعه کامپوننت‌های سفارشی قابل استفاده مجدد

  • پیاده‌سازی کامپوننت‌های UI قابل استفاده مجدد
  • استفاده از Hooks سفارشی برای بهبود قابلیت‌های کامپوننت‌ها
  • مدیریت وضعیت کامپوننت‌ها با Context API
  • توسعه کامپوننت‌های قابل استفاده در پروژه‌های مختلف
  • مستندسازی کامپوننت‌ها با Storybook
  • استفاده از TypeScript برای بهبود قابلیت استفاده مجدد
  • بهینه‌سازی عملکرد کامپوننت‌ها با استفاده از memoization
  • پیاده‌سازی تست‌های واحد برای کامپوننت‌های سفارشی
  • استفاده از Design Systems برای بهبود کامپوننت‌های سفارشی
  • انتشار کامپوننت‌های قابل استفاده در npm یا GitHub

سطح 17: بهینه‌سازی SEO در Next.js

  • پیاده‌سازی بهترین روش‌ها برای SEO در Next.js
  • استفاده از Head برای مدیریت meta tags
  • بهینه‌سازی اپلیکیشن برای موتورهای جستجو
  • استفاده از Open Graph و Twitter Cards برای بهینه‌سازی اشتراک‌گذاری
  • پیاده‌سازی Sitemap و robots.txt
  • مدیریت و بهینه‌سازی صفحات 404 و خطاها برای SEO
  • استفاده از Lighthouse برای بررسی امتیاز SEO
  • بهبود زمان بارگذاری صفحات برای بهینه‌سازی تجربه کاربر
  • استفاده از داده‌های ساخت‌یافته (Structured Data) برای بهبود SEO
  • بررسی و مدیریت لینک‌های داخلی برای بهینه‌سازی بهتر

سطح 18: استفاده از GraphQL با Next.js

  • استفاده از GraphQL برای مدیریت داده‌ها در Next.js
  • پیاده‌سازی سرور GraphQL با استفاده از Apollo Server
  • استفاده از Apollo Client برای فچینگ داده‌ها در Next.js
  • مدیریت کوئری‌ها و mutation‌ها با GraphQL
  • پیاده‌سازی سیستم caching در GraphQL
  • استفاده از GraphQL برای مدیریت داده‌های real-time
  • تست کوئری‌ها و mutation‌ها با ابزارهای GraphQL
  • مدیریت ارتباطات پیچیده داده‌ها با استفاده از GraphQL
  • استفاده از TypeScript برای بهینه‌سازی استفاده از GraphQL
  • پیاده‌سازی اشتراک‌گذاری داده‌ها (subscriptions) در GraphQL

سطح 19: ایجاد اپلیکیشن‌های Isomorphic

  • درک مفهوم Isomorphic Apps (SSR + CSR)
  • پیاده‌سازی اپلیکیشن‌های همگانی با Next.js
  • مدیریت رندرینگ سمت سرور و کلاینت به صورت ترکیبی
  • بهینه‌سازی زمان بارگذاری و تجربه کاربری در اپلیکیشن‌های Isomorphic
  • مدیریت فچینگ داده‌ها در هر دو سمت کلاینت و سرور
  • پیاده‌سازی بهینه‌سازی SSR برای بهبود سرعت صفحات
  • استفاده از React Hydration برای مدیریت رندرینگ سمت کلاینت
  • پیاده‌سازی Isomorphic Routing و فچینگ داده‌ها
  • مدیریت حالت‌ها و session‌ها در اپلیکیشن‌های Isomorphic
  • تست و دیباگ اپلیکیشن‌های Isomorphic

سطح 20: رهبری تیم‌های توسعه و معماری‌های پیچیده

  • رهبری تیم‌های توسعه Next.js
  • طراحی و پیاده‌سازی معماری‌های مقیاس‌پذیر
  • مدیریت پروژه‌های بزرگ با Next.js و تکنولوژی‌های مرتبط
  • ایجاد سیستم‌های CI/CD پیشرفته برای تیم‌های بزرگ
  • استفاده از Agile و Scrum برای مدیریت فرآیند توسعه
  • ارائه راهکارهای بهینه‌سازی برای اپلیکیشن‌های پیچیده
  • مدیریت منابع و تخصیص کار در تیم‌های چند نفره
  • پیاده‌سازی راهکارهای امنیتی برای اپلیکیشن‌های بزرگ
  • مدیریت ارتباطات بین تیم‌ها و بخش‌های مختلف پروژه
  • تحلیل و ارزیابی عملکرد تیم و پروژه برای بهبود فرآیند‌ها
تعداد ظرفیت باقی مانده : 200 نفر
اطلاع رسانی ها
پیام ها