الفرق بين المراجعتين لصفحة: «Next.js»
جميل-بيلوني (نقاش | مساهمات) لا ملخص تعديل |
جميل-بيلوني (نقاش | مساهمات) |
||
سطر 159: | سطر 159: | ||
==[[Next.js/going_to_production|ما قبل مرحلة الإنتاج]]== | ==[[Next.js/going_to_production|ما قبل مرحلة الإنتاج]]== | ||
يعرض بعض النصائح المهمة لتضمن أفضل تجربة مستخدم عندما تصل بتطبيق Next.js إلى مرحلة الإنتاج. | |||
== [[Next.js/deployment|نشر تطبيقات Next.js]] == | == [[Next.js/deployment|نشر تطبيقات Next.js]] == | ||
يشرح هذا القسم كيفية نشر تطبيقات Next.js سواء المُدارة managed أو ذاتية الإدارة Self-hosted باستخدام الواجهة البرمجية لبناء التطبيقات. | |||
== [[Next.js/authentication|الاستيثاق Authentication]] == | == [[Next.js/authentication|الاستيثاق Authentication]] == | ||
تقدم لك Next.js أنماطًا متعددة من الاستيثاق وصُمم كل نمط لحالة مختلفة. سنمر في هذا القسم على كل حالة لتتمكن من الاختيار بناء على المعطيات المتوفرة لديك. | |||
== [[Next.js/testing|اختبار تطبيقات Next.js]] == | == [[Next.js/testing|اختبار تطبيقات Next.js]] == | ||
نلقي نظرة في هذا القسم على طرق اختبار تطبيقات Next.js باستخدادم أدوات مثل Cypress و Playwright و Jest مع مكتبة اختبار React. | |||
== [[Next.js/building forms|دليل بناء النماذج]] == | == [[Next.js/building forms|دليل بناء النماذج]] == | ||
يساعدك هذا الدليل في تعلّم كيفية إنشاء نموذج ويب web form باستخدام Next.js. | |||
== ميزات متقدمة == | == ميزات متقدمة == | ||
=== [[Next.js/compiler|مُصرِّف Next.js]] === | === [[Next.js/compiler|مُصرِّف Next.js]] === | ||
يشرح هذا القسم مُصرِّف Next.js المُستخدم الذي كتب بلغة Rust باستخدام [http://swc.rs/ SWC] بتحويل وتصغير شيفرة [[JavaScript]] لتصبح مناسبة لمرحلة الإنتاج، وبالتالي حل مكان Babel بالنسبة للملفات المستقلة و Terser لتصغير الحزم الناتجة. | |||
=== [[Next.js/preview_mode|نمط استعراض الصفحات]] === | === [[Next.js/preview_mode|نمط استعراض الصفحات]] === | ||
يعرض القسم ميزة توفرها Next.js تُدعى نمط الاستعراض Preview Mode وطريقة استخدامها في حل بعض المشكلات خصوصًا المتعلقة باستخدام Next.js في إحضار بيانات من منظومة إدارة محتوى دون واجهة headless CMS. | |||
=== [[Next.js/dynamic_import|الإدراج الديناميكي]] === | === [[Next.js/dynamic_import|الإدراج الديناميكي]] === | ||
يشرح هذا القسم الدعم الذي توفره Next.js لعملية الإدراج الكسول أو المتأني lazy loading للمكتبات الخارجية عبر <code>import()</code> وللمكونات [[React]] عبر <code>next/dynamic</code>. | |||
=== [[Next.js/automatic_static_optimization|التحسين الساكن التلقائي]] === | === [[Next.js/automatic_static_optimization|التحسين الساكن التلقائي]] === | ||
يشرح القسم ميزة التحسين الساكن التلقائي التي توفرها Next.js لنشر تطبيقات هجينة تتضمن صفحات تُصيَّر من ناحية الخادم وأخرى توّلد بشكل ساكن. | |||
=== [[Next.js/static_html_export|تصدير التطبيق إلى صفحات HTML ساكنة]] === | === [[Next.js/static_html_export|تصدير التطبيق إلى صفحات HTML ساكنة]] === | ||
يشرح القسم كيفية تصدير تطبيق Next.js إلى صفحات HTML ساكنة قائمة بحد ذاتها دون الحاجة إلى خادم Node.js. | |||
=== [[Next.js/module_path_aliases|المسارات المطلقة البديلة للمُدرجات و الوحدات البرمجية]] === | === [[Next.js/module_path_aliases|المسارات المطلقة البديلة للمُدرجات و الوحدات البرمجية]] === | ||
دعمت Next.js تلقائيًا الخيارين <code>"paths"</code> و <code>"baseUrl"</code> في ملفي التهيئة <code>tsconfig.json</code> و <code>jsconfig.json</code> اللذين يتيحين تهيئة مسارات بديلة aliases للوحدات البرمجية، ولهذين الخيارين ميزة مفيدة هي تكاملها التلقائي مع بعض محررات الشيفرة مثل vscode وهذا ما يشرحه هذا القسم. | |||
=== [[Next.js/using_mdx|استخدام MDX مع Next.js]] === | === [[Next.js/using_mdx|استخدام MDX مع Next.js]] === | ||
تدعم Next.js صيغة MDX -وهي صيغة موّسعة تُشتق منها تنسيقات ماركداون markdown- بطرق مختلفة، وسيرشدك هذا القسم إلى بعض طرق تكامل MDX مع تطبيقات Next.js. | |||
=== [[Next.js/amp_support|دعم صفحات AMP]] === | === [[Next.js/amp_support|دعم صفحات AMP]] === | ||
يشرح القسم الدعم الذي توفره Next.js لتحويل صفحات React إلى صفحات [https://amp.dev/ AMP] بأقل قدر من الإعدادات ودون أن تتخلى عن React. | |||
=== [[Next.js/customizing_babel_config| | ===[[Next.js/customizing_babel_config|تخصيص ضبط Babel]]=== | ||
يشرح القسم كيفية توسيع إعدادات Babel الافتراضية التي تضيفها Next.js إلى التطبيق. | |||
=== [[Next.js/customizing_postcss_config|إعدادات مخصصة للمصرّف PostCSS]] === | === [[Next.js/customizing_postcss_config|إعدادات مخصصة للمصرّف PostCSS]] === | ||
تقدم Next.js دعمًا مدمجًا لتنسيقات [[CSS]]، ويشرح هذا القسم كيفية تهيئة المصرِّف الخاص بهذه التنسيقات وتخصيصه. | |||
=== [[Next.js/custom_server|استخدام خادم مخصص]] === | === [[Next.js/custom_server|استخدام خادم مخصص]] === |
مراجعة 17:03، 4 يناير 2023
إن أردت بناء تطبيق ويب باستخدام مكتبة React فقط، فهنالك عدة نقاط يجب أن تراعيها وتأخذها بالحسبان وهي:
- يجب أن تُجمَّع الشيفرة عبر مُجمِّع bundler مثل webpack وأن تُحوَّل باستعمال مُصرِّف مثل Babel.
- عليك أن تجري تحسينات على نسخة الإنتاج مثل فصل الشيفرة وتقسيمنها إلى أجزاء.
- قد تحتاج إلى تجهيز بعض الصفحات مسبقًا قبل إرسلها إلى المستخدم أو العميل لعدة أغراض أهمها تحسين الأداء وتحسين الظهور في محركات البحث SEO، وقد تضطر إلى استخدام عميلة التصيير من طرف الخادم server-side rendering أو التصيير من طرف العميل client-side rendering.
- قد تحتاج إلى كتابة شيفرة تعمل من طرف الخادم لتربط تطبيق React مع مصدر بيانات.
أولًا وآخرًا تُعد React مكتبة library قائمة على لغة JavaScript وتفتقر إلى أجزاء أخرى لتُكمِّل عملها وهنا تظهر الحاجة إلى استخدام إطار عمل framework يوفر حلولًا متكاملة للنقاط السابقة وغيرها ويُفضل أن يتصف إطار العمل بمستوًى جيد من المرونة والتجريد وإلا لن يخدم احتياجك عكس المكتبة آنذاك التي من أهم ميزتها أنها توفر لك خيارات متعددة من التخصيص والتجريد لحاجتك.
يمكنك أن تتخيل أن المكتبة مثل قطعة مُكعَّبات أو ليجو lego يمكنك تركيبها مع بقية القطع التي تختارها بما يناسب احتياجك وما تريد بناءه، أما إطار العمل فهو يشبه صندوق فيه أجزاء جاهزة جاهزة للعمل كل ما عليك تخصيصها ووصلها مع بعضها لتعمل بما يناسب احتياجك وهنا تختلف أُطر العمل بمقدار هذا التخصيص ومرونة التعديل وضبط الخيارات فيها.
جاء إطار العمل Next.js وهو إطار عمل مبني على مكتبة React ليوفر حلولًا لجميع النقاط السابقة التي تواجه أي مُطور أثناء عملية بناء تطبيق ويب والأهم من ذلك أنه يأخذ بيد المُطور وفريق التطوير كله إلى النجاح بل وحتى السرعة والكفاءة في عملية بناء تطبيقات React.
أُطلق إطار العمل Next.js في أواخر عام 2016 بواسطة شركة Vercel وآخر إصدار مُستقر له حاليًا 13.0.2 وهو مشروع مفتوح المصدر مكتوب بلغة JavaScript و TypeScript ولغة Rust ويشرف عليه مُطورون من شركة Vercel ومجتمع المصادر المفتوحة وتملك تلك الشركة اليوم حقوقه وعلامته التجارية وتديره حاليًا وتقود عملية تطويره في أوساط المجتمع وتمثِّل الداعم الأكبر والمساهم الرئيسي؛ وقد شاع استخدامه كثيرًا فقد تجاوز عدد مرات استخدامه اليوم عشرات الآلاف بين مواقع وتطبيقات ويب.
يهدف إطار العمل Next.js إلى توفير تجربة تطوير مميزة ويقدم الكثير من الميزات الضمنية مثل:
- نظام توجيه قائم على الملفات مع دعم الوجهات الديناميكية dynamic routes.
- إجراء عملية تصيير مُسبق pre-rendering بدعم عملية التوليد الساكن SSG والتصيير من جانب الخادم SSR على كل صفحة.
- فصل الشيفرة وتقسييمها لتحميل الصفحة بسرعة.
- دعم التوجيه من طرف الخادم مع إجراء عملية جلب مُسبقة.
- دعم تنسيقات CSS وامتدادها Sass بالإضافة إلى دعم أي آلية كتابة تنسيقات CSS في شيفرة JavaScript واختصارًا CSS-in-JS.
- توفير بيئة تطوير متكاملة مع دعم التحديث السريع.
- دعم إضافة واجهة برمجية خلفية API endpoints مع دوال دون خادم Serverless Functions.
- قابلية كبيرة للتوسيع والضبط والتخصيص.
البدء مع Next.js
مرحبًا بك إلى توثيق Next.js باللغة العربية!
متطلبات النظام:
- حزمة Node.js نسختها 14.6.0 أو أعلى
- نظام تشغيل ماك أو ويندوز (بما في ذلك منظومة ويندوز الفرعية لدعم لينكس WSL) أو لينكس.
التثبيت التلقائي لإطار عمل Next.js
من الأفضل أن تُنشئ تطبيقًا جديدًا باستخدام create-next-app
وستثبت هذه العملية كل ما تحتاجه تلقائيًا. لإنشاء تطبيق جديد، اكتب التعليمات التالية في طرفية Node.js:
npx create-next-app@latest
# or
yarn create next-app
# or
pnpm create next-app
بإمكانك استخدام الراية typescript--
إن أردت ان تبدأ بمشروع TypeScript:
npx create-next-app@latest --typescript
# or
yarn create next-app --typescript
# or
pnpm create next-app -- --typescript
عند اكتمال التثبيت:
- شغل خادم التطوير على العنوان
http://localhost:3000
مستخدمًا إحدى التعليمات التالية:npm run dev
yarn dev
pnpm dev
- زر العنوان السابق للاطلاع على تطبيقك.
- عدّل الصفحة
pages/index.js
وراقب نتيجة ما فعلته في المتصفح.
لمزيد من المعلومات حول create-next-app
، حاول الإطلاع على التوثيق الخاصة به.
التثبيت اليدوي
ثبت next
و react
و react-dom
في مشروعك كالتالي:
npm install next react react-dom
# or
yarn add next react react-dom
# or
pnpm add next react react-dom
افتح الملف package.json
ثم أضف الشيفرة التالية:
"scripts": {
"dev": "next dev",
"build": "next build",
"start": "next start",
"lint": "next lint"
}
تشير هذه الشيفرة إلى المراحل المختلفة لتطوير التطبيق:
dev
: ينفذ الأمرnext dev
للعمل مع Next.js في نمط التطوير.build
: ينفذ الأمرnext build
لبناء تطبيق يعمل في نمط الإنتاج.start
: ينفذ الأمرnext start
لتشغيل خادم إنتاج Next.js.lint
: ينفذ الأمرnext lint
لتهيئة مدقق ESLint المدمج مع Next.js.
أنشئ بعد ذلك مجلدين الأول يحمل الاسم pages
والآخر public
ضمن الملف الجذري لتطبيقك:
pages
: ويمثل جذرًا لعناوبن الملفات التي يضمها، إذ يقترن المسارpages/about.js
مثلًا بالمسارabout/
.public
: يخزّن موارد الدعم كالصور وخطوط الكتابة وغيرها. يمكن الإشارة إلى الملفات الموجودة ضمن هذا المجلد انطلاقًا من العنوان الجذري/
تمامًا كالملفات الموجودة ضمنpages
.
بُنيت Next.js على مفهوم الصفحات، والصفحة هي مكوّن رياكت React Component يُصدَّر من ملفات موجودة في المجلد pages
تحمل إحدى الامتدادات التالية js.
أو jsx.
أو ts.
أو tsx.
. بإمكانك أيضًا إضافة معاملات المسارات الديناميكية مع اسم الملف.
ضع الملف index.js
في المجلد pages
حتى تبدأ العمل، فهي الصفحة التي يعرضها المتصفح عند زيارة المجلد الجذري لتطبيقك. وطّن الصفحة pages/index.js
(اجعلها الصفحة الرئيسية) بإضافة المحتوى التالي لها:
function HomePage() {
return <div>Welcome to Next.js!</div>
}
export default HomePage
بعد اكتمال التثبيت:
- نفّذ أحد الأوامر التالية لتشغّل خادم التطوير على العنوان
http://localhost:3000
:npm run dev
yarn dev
pnpm dev
- زر العنوان
http://localhost:3000
لاستعراض تطبيقك - عدّل في الصفحة
pages/index.js
لترى النتيجة مباشرة على متصفحك.
ما فعلناه حتى اللحظة:
- تصريف compiling و تجميع bundling تلقائي.
- تهيئة التحديث السريع لرياكت React Fast Refresh.
- تقديم الملفات الثابتة Static file serving من خلال المسار
public/
المرتبط بالعنوان الجذري/
.
سيكون كل تطبيق جاهزًا لمرحلة الإنتاج ابتداءً من لحظة إنشائه، وهذا ما سنراه في توثيق توزيع التطبيقات.
الميزات الأساسية
الصفحات Pages
يشرح القسم الصفحة page وهي مكوّن React موجودة في المجلد pages
وتقترن كل صفحة بأحد مسارات التطبيق.
إحضار البيانات
تتيح عملية إحضار البيانات في Next.js تصيير المحتوى بطرق عدة وفقًا للحالة التي تستخدم فيها التطبيق، بما في ذلك التصيير المسبق من جانب الخادم Server-Side Rendering أو التوليد الساكن للشيفرة Static Generation أو تحديث المحتوى أو إنشائه أثناء تشغيل التطبيق من خلال التوليد الساكن التدريجي Incremental Static Regeneration وهذا ما يشرحه هذا القسم.
دعم تنسيقات CSS المدمجة
يشرح القسم كيف تتيح Next.js إدراج ملفات تنسيق CSS من خلال ملف JavaScript، وهذا ممكن لأن Next.js توسِّع مفهوم الإدراج import
أكثر مما هو عليه في JavaScript.
تخطيطات الصفحة Layouts
يشرح القسم كيف يمكن الاستفادة من مكونات واستخدامها في عدة صفحات تمثِّل شكل الصفحة وتخطيطها، فقد يكون للصفحات مثلًا شريط التنقل نفسه والتذييل نفسه ولا يُكرر تعريفه آنذاك.
تحسين الصور
يُعدّ مكون الصورة في Next.js امتدادًا لعنصر الصورة <img>
في HTML وقد طُوِّر ليماشي تقنيات ويب الحديثة وهو ما يشرحه هذا القسم.
تحسين خطوط الكتابة
يشرح القسم الآلية المدمجة التي تمتلكها Next.js وتطبقها لتحسين خطوط الكتابة في التطبيق.
تخديم الملفات الساكنة
يشرح القسم كيف تُخدِّم Next.js الملفات الساكنة static files وهي الملفات الثابتة التي لا تتغير مثل الصور التي توجد في المجلد public
ضمن المجلد الجذري.
التحديث السريع
يشرح القسم ميزة التحديث السريع Fast Refresh في Next.js التي تعطيك فكرة مباشرة عن التغييرات التي جرت على مكوّنات React.
استخدام مدقق الشيفرة ESLint
يشرح القسم كيفية استخدام مدقق القواعد ESLint، الذي توفر Next.js له دعمًا داخليًا.
استخدام TypeScript
يشرح القسم كيفية استخدام لغة TypeScript بما في ذلك التهيئة والأنواع في تطبيقات Next.js.
متغيرات البيئة
يشرح القسم متغيرات البيئة Environment Variables واستخدامها في تطبيقات Next.js عبر الدعم الذي توفره.
المتصفحات والميزات المدعومة
يعرض القسم الدعم الذي توفره Next.js لمختلف المتصفحات بمختلف إصداراتها وكيفية استهدات إصدارات أو ميزات محددة من المتصفحات وكيفية إضافة شيفرات موائمة polyfills لها.
التعامل مع السكربتات
يشرح القسم كيفية استخدام العنصر <script>
تطبيق Next.js الذي يتيح تحديد أولوية تحميل السكربتات التي مصدرها طرف آخر خارجي في التطبيق وتحسين الأداء.
التوجيه Routing
توجيه المسارات
يشرح القسم موجه المسارات router الذي توفره Next.js والذي يعتمد على نظام ملفات مبني على مفهوم الصفحات.
مسارات الواجهة البرمجية API Routes
يعرض القسم طريقة بناء الواجهة البرمجية الخلفية API لتطبيقك باستخدام Next.js الذي يعمل في هذه الحالة كواجهة أمامية frontend وواجهة خلفية backend في الوقت نفسه.
ما قبل مرحلة الإنتاج
يعرض بعض النصائح المهمة لتضمن أفضل تجربة مستخدم عندما تصل بتطبيق Next.js إلى مرحلة الإنتاج.
نشر تطبيقات Next.js
يشرح هذا القسم كيفية نشر تطبيقات Next.js سواء المُدارة managed أو ذاتية الإدارة Self-hosted باستخدام الواجهة البرمجية لبناء التطبيقات.
الاستيثاق Authentication
تقدم لك Next.js أنماطًا متعددة من الاستيثاق وصُمم كل نمط لحالة مختلفة. سنمر في هذا القسم على كل حالة لتتمكن من الاختيار بناء على المعطيات المتوفرة لديك.
اختبار تطبيقات Next.js
نلقي نظرة في هذا القسم على طرق اختبار تطبيقات Next.js باستخدادم أدوات مثل Cypress و Playwright و Jest مع مكتبة اختبار React.
دليل بناء النماذج
يساعدك هذا الدليل في تعلّم كيفية إنشاء نموذج ويب web form باستخدام Next.js.
ميزات متقدمة
مُصرِّف Next.js
يشرح هذا القسم مُصرِّف Next.js المُستخدم الذي كتب بلغة Rust باستخدام SWC بتحويل وتصغير شيفرة JavaScript لتصبح مناسبة لمرحلة الإنتاج، وبالتالي حل مكان Babel بالنسبة للملفات المستقلة و Terser لتصغير الحزم الناتجة.
نمط استعراض الصفحات
يعرض القسم ميزة توفرها Next.js تُدعى نمط الاستعراض Preview Mode وطريقة استخدامها في حل بعض المشكلات خصوصًا المتعلقة باستخدام Next.js في إحضار بيانات من منظومة إدارة محتوى دون واجهة headless CMS.
الإدراج الديناميكي
يشرح هذا القسم الدعم الذي توفره Next.js لعملية الإدراج الكسول أو المتأني lazy loading للمكتبات الخارجية عبر import()
وللمكونات React عبر next/dynamic
.
التحسين الساكن التلقائي
يشرح القسم ميزة التحسين الساكن التلقائي التي توفرها Next.js لنشر تطبيقات هجينة تتضمن صفحات تُصيَّر من ناحية الخادم وأخرى توّلد بشكل ساكن.
تصدير التطبيق إلى صفحات HTML ساكنة
يشرح القسم كيفية تصدير تطبيق Next.js إلى صفحات HTML ساكنة قائمة بحد ذاتها دون الحاجة إلى خادم Node.js.
المسارات المطلقة البديلة للمُدرجات و الوحدات البرمجية
دعمت Next.js تلقائيًا الخيارين "paths"
و "baseUrl"
في ملفي التهيئة tsconfig.json
و jsconfig.json
اللذين يتيحين تهيئة مسارات بديلة aliases للوحدات البرمجية، ولهذين الخيارين ميزة مفيدة هي تكاملها التلقائي مع بعض محررات الشيفرة مثل vscode وهذا ما يشرحه هذا القسم.
استخدام MDX مع Next.js
تدعم Next.js صيغة MDX -وهي صيغة موّسعة تُشتق منها تنسيقات ماركداون markdown- بطرق مختلفة، وسيرشدك هذا القسم إلى بعض طرق تكامل MDX مع تطبيقات Next.js.
دعم صفحات AMP
يشرح القسم الدعم الذي توفره Next.js لتحويل صفحات React إلى صفحات AMP بأقل قدر من الإعدادات ودون أن تتخلى عن React.
تخصيص ضبط Babel
يشرح القسم كيفية توسيع إعدادات Babel الافتراضية التي تضيفها Next.js إلى التطبيق.
إعدادات مخصصة للمصرّف PostCSS
تقدم Next.js دعمًا مدمجًا لتنسيقات CSS، ويشرح هذا القسم كيفية تهيئة المصرِّف الخاص بهذه التنسيقات وتخصيصه.