المتصفحات والميزات المدعومة في Next.js
تدعم Next.js المتصفح IE11 وجميع المتصفحات الحديثة (Edge و Firefox و Chrome و Safari و Opera وغيرها) دون الحاجة إلى أية تهيئة إضافية.
موائمة الشيفرة لدعم المتصفحات المختلفة في Next.js
تدفع Next.js صراحةً بشيفرات موائمة polyfills لازمة لدعم المتصفح IE11 كما تدفع بشيفرات موائمة مستخدمة على نطاق واسع بما فيها:
- ()fetch: يستبدل
whatwg-fetch
وunfetch
- URL: يستبدل حزمة url (في واجهة Node.js البرمجية )
- ()Object.assign: يستبدل
object-assign
وobject.assign
وcore-js/object/assign
.
إن احتوت أية اعتمادية من اعتمادياتك على هذه الشيفرات فستُحذف تلقائيًا من نسخة الإنتاج لتفادي التكرار. ولتقليل حجم التجميعات، تُحمِّل Next.js شيفرات الموائمة هذه للمتصفحات التي تحتاجها، بينما لن تراها في بقية الحالات.
شيفرات الموائمة من جانب الخادم
تدفع Next.js بالدالة ()fetch
لموائمة الشيفرة في بيئة عمل على الخادم بالإضافة إلى بيئة العميل. وبإمكانك استخدام ()fetch
في الشيفرة التي تنفذها على الخادم (مثل getStaticProps
أو getServerSideProps
) دون الحاجة لاستخدام شيفرات موائمة مثل isomorphic-unfetch
أو node-fetch
.
شيفرات موائمة مخصصة
إن احتاجت شيفرتك أو أية اعتمادية من اعتماديات npm إلى ميزات لا يدعمها المتصفح المستهدف، فلا بد من موائمة الشيفرة بنفسك. عليك في هذه الحالات إضافة عبارة إدراج import (من المستوى الأعلى) لشيفرة الموائمة المحددة التي تحتاجها في تطبيقك المخصص أو في المكوِّن المطلوب.
دعم ميزات JavaScript في Next.js
تتيح Next.js استخدام آخر ميزات صدرت للغة JavaScript. إذ تدعم إضافة إلى ميزات ES6 ما يلي:
- الدوال غير المتزامنة ودوال الانتظار Async/await الإصدار (ES2017) من JavaScript
- Object Rest/Spread Properties الإصدار (ES2018) من JavaScript
- دالة
()import
الديناميكية ()Dynamic import الإصدار (ES2020) من JavaScript - السلسلة الاختيارية Optional Chaining الإصدار (ES2020) من JavaScript
- الدمج اللاغي Nullish Coalescing الإصدار (ES2020) من JavaScript
- حقول الأصناف Class Fields والخاصيات الساكنة Static Properties (جزء من اقتراحات المرحلة 3).
- وغيرها الكثير.
دعم ميزات TypeScript
تدعم Next.js اللغة TypeScript بميزات مدمجة معها. اطلع على الصفحة التي توثق هذا الموضوع.
تخصيص إعدادات ناقل الشيفرة Babel
يمكنك الاطلاع على الموضوع بصورة أوسع في الصفحة الخاصة بتهيئة Babel.
المصادر
- الصفحة Supported Browsers and Features في Next.js توثيق الرسمي