الفرق بين المراجعتين لصفحة: «Next.js/Topics»

من موسوعة حسوب
لا ملخص تعديل
لا ملخص تعديل
سطر 62: سطر 62:
== [[Next.js/testing|اختبار تطبيقات Next.js]] ==
== [[Next.js/testing|اختبار تطبيقات Next.js]] ==
نلقي نظرة في هذا القسم على طرق اختبار تطبيقات Next.js باستخدادم أدوات مثل Cypress و Playwright و Jest مع مكتبة اختبار React.
نلقي نظرة في هذا القسم على طرق اختبار تطبيقات Next.js باستخدادم أدوات مثل Cypress و Playwright و Jest مع مكتبة اختبار React.
== شمولية الوصول في Next.js ==
يقدم لك حلول Next.js في دعم شمولية الوصول accessibility سواء للمطورين أو مستخدمي المنتجات النهائية التي تعتمد على Next.js.


== [[Next.js/building forms|دليل بناء النماذج]] ==
== [[Next.js/building forms|دليل بناء النماذج]] ==

مراجعة 13:51، 18 يناير 2023

بدء استخدام Next.js

يشرح هذا القسم متطلبات إطار العمل Next.js اللازمة وكيفية تثبيته وبدء استخدامه.

الميزات الأساسية

الصفحات 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.

شمولية الوصول في Next.js

يقدم لك حلول Next.js في دعم شمولية الوصول accessibility سواء للمطورين أو مستخدمي المنتجات النهائية التي تعتمد على Next.js.

دليل بناء النماذج

يساعدك هذا الدليل في تعلّم كيفية إنشاء نموذج ويب 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، ويشرح هذا القسم كيفية تهيئة المصرِّف الخاص بهذه التنسيقات وتخصيصه.

استخدام خادم مخصص

تستخدم Next.js خادمها الافتراضي عند تنفيذ الأمر next start، لكن إن كانت لديك واجهة خلفية جاهزة ستتمكن من استخدامها في Next.js والاعتماد على خادم مخصص وهذا ما يشرحه هذا القسم.

التطبيقات المخصصة باستخدام المكون App

يشرح القسم كيفية تخصيص المكوّن App لتهيئة الصفحات تهيئة مخصصة كما تريد.

المستندات المخصصة باستخدام المكون Document

يشرح القسم كيفية تخصيص المكوّن Document الافتراضي في التطبيق الذي يُستخدم في جانب الخادم فقط.

صفحات مخصصة لعرض الأخطاء

يعرض القسم مجموعة الصفحات التي يمكن تخصيصها لعرض أخطاء الاتصال بالخادم بالطريقة التي يريدها المطور.

المجلد src

يشرح القسم إمكانية إضافة الصفحات في المجلد src/pages كبديل عن المجلد الجذري pages.

دمج التطبيقات المفردة (الحيزات)

يُطلق اسم حيّز Zone على توزيعة مفردة من تطبيق Next.js، وبإمكانك دمج عدة حيّزات في تطبيق واحد وهذا ما يعرضه القسم.

قياس الأداء في تطبيقات Next.js

يشرح القسم كيفية تحليل أداء تطبيقات Next.js وقياس أداء الصفحات بناءً على مؤشرات مختلفة.

الأدوات الوسطية Middleware

يشرح القسم الأدوات أو البرمجيات الوسيطة التي تُمكنك من تنفيذ مهمة قبل اكتمال كل طلب request وتعديل الرد بناءً على الطلب الوارد من خلال إعادة كتابة أو إعادة التوجيه أو إضافة الترويسات أو حتى بالرد على الطلب مباشرة.

تنقيح تطبيقات Next.js

يشرح هذا القسم كيفية تنقيح شيفرة الواجهتين الأمامية والخلفية بدعم كامل لملفات الربط المصدرية source maps وذلك باستخدام منقح VS Code أو أدوات مطورري ويب المدمجة مع المتصفح Google Chrome.

معالجة الأخطاء

يشرح هذا القسم كيفية معالج الأخطاء في كلتا الواجهتين الأمامية والخلفية في مرحلة التطوير.

ملفات الربط المصدرية

يشرح القسم آلية ضبط ملفات الربط المصدرية Source Maps في مرحلة البناء للتطبيق.

تحويلات Codemods

تقدم Next.js تحويلات Codemod تساعد على ترقية ملفات شيفرة تطبيق Next.js لتعديل ميزة توقف دعمها ويعرض هذا القسم جميع تلك التحويلات المتوفرة.

الوجهات العالمية i18n routing

يشرح القسم الدعم المدمج الذي تقدمه Next.js للوجهات العالمية internationalized (i18n) routing وكيفية ضبطها.

تتبع ملفات الخرج

يشرح القسم ميزة تتبع ملفات الخرج في المجلد /next. التي توفرها Next.js.

ترويسات الأمان

يشرح القسم الترويسات headers المُستخدمة في ملف التهيئة next.config.js لتطبيق ترويسات استجابة HTTP على جميع الوجهات في التطبيق لتحسين مستوى الأمان فيه.

استخدام React 18

يسلط القسم الضوء على الميزات الحديثة التي قدمها الإصدار 18 من React ودعمها في تطبيقات Next.js.

دليل ترقية إصدارات Next.js

يعرض القسم قائمة بالتغييرات التي تحدث عند ترقية إصدارات Next.js والمتطلبات اللازمة لكل منها.

الانتقال إلى Next.js

يشرح القسم كيفية الانتقال تدريجيًا إلى Next.js وتبنيها دون الحاجة إلى إعادة كتابة كل شيء من الصفر.

الأسئلة الأكثر شيوعًا حول Next.js

يعرض القسم بعض الأجوبة عن أكثر الأسئلة شيوعًا حول Next.js.

مرجع الواجهة البرمجية API Reference

واجهة سطر الأوامر

تسمح لك واجهة سطر الأوامر CLI في تشغيل وبناء وتصدير نسخة إنتاج من تطبيق Next.js.

الأداة Create Next App

إن أسهل الطرق لتبدأ بناء تطبيقات Next.js هو استخدام الأداة create-next-app التي تمكنك هذه الأداة التي تستخدم واجهة سطر الأوامر CLI أن تبدأ بناء تطبيق Next.js جديد بسرعة بعد أن تهيئ لك كل شئ.

المكون next/router

يشرح القسم الخطاف useRouter والخطاف withRouter مع الكائن router الذي يمثِّل المُوجِّه.

المكون next/link

يشرح القسم مكون الرابط Link وخاصياته المستورد عبر next/link. المُستخدم في التنقل بين الصفحات أو الوجهات في جانب العميل.

المكون next/image

يشرح القسم مكون الصورة الجديد وخاصياته المستورد عبر next/image.

المكون next/legacy/image

يشرح القسم مكون الصورة القديم وخاصياته المستورد عبر next/legacy/image.

المكون next/script

يشرح القسم مكون السكربت script وخاصياته المستورد عبر next/script.

المكون next/head

يشرح القسم مكون الترويسة واستخدامه المستورد عبر next/head المستخدم في ربط العناصر إلى ترويسة الصفحة <head>.

المكون next/amp

يشرح القسم كيفية تمكين دعم صفحات AMP.

المكون next/server

يشرح القسم المكون next/server الذي يقدم مجموعة من دوال مساعدة تعمل على الخادم فقط وتُستخدم من قبل البرمجيات الوسيطة أو وجهات API المتقدمة.

المُشغل الآني المتقدم Edge Runtime

يعتمد المُشغل الآني المتقدم Edge Runtime في Next.js على واجهات الويب البرمجية Web API التي تُستخدم من قبل البرمجيات الوسيطة أو وجهات API المتقدمة.

الواجهة البرمجية لإحضار البيانات

يعرض القسم الواجهة البرمجية للدوال التي تستخدمها Next.js في إحضار البيانات وهي:

  • getInitialProps
  • getServerSideProps
  • getStaticPaths
  • getStaticProps

مؤشر التحسين الساكن

يعرض القسم كيفية ضبط مؤشر التحسين الساكن autoPrerender ضمن devIndicators.

العمل مع ملف التهيئة next.config.js

يشرح القسم كافة الإعدادات التي يمكن ضبطها في ملف التهيئة next.config.js لتطبيق إعدادت متقدمة على تطبيق Next.js.