ما هي TypeScript؟

خصائص TypeScript، واستخدامها في العالم الحقيقي مع أمثلة، واختلافها عن لغات أخرى، وإجابات مفسّرة عن السكون والديناميكية للأنواع، ودعم البرمجة كائنية التوجّه، وكونها لغة عالية المستوى، وما إذا كانت تُصرَّف ثم تُنفَّذ كـJavaScript في المحرّكات.

TypeScript شبيهة بحواجز أمان مرنة أثناء تطوير البرمجيات. لا تبني التطبيق كاملاً بمفردها، ولا تختار أهداف المنتج بدلاً عن الفريق. بدلاً من ذلك تدعم المبرمجين أثناء الكتابة عبر تنبيههم عند خطأ واضح، ما يقلل احتمال أن تتحول أخطاء صغيرة إلى أعطال أكبر لاحقاً.

ما هي TypeScript؟

TypeScript لغة من Microsoft بُنيت فوق JavaScript. يمكن وضع JavaScript المعتادة ضمن مشروع TypeScript، وتُضاف فوق ذلك الأنواع الساكنة والواجهات والتحقق من الأنواع. ثم يحوِّل مُصرِّف TypeScript الشيفرة إلى JavaScript عادي ليعمل المتصفح أو أدوات مثل Node.js.

مخطط بأسلوب أويلر: دائرة JavaScript أصغر بالكامل داخل دائرة TypeScript أكبر.
JavaScript جزء فرعي (subset) من TypeScript.

أثناء التحرير، تربط محرّرات الشيفرة المتقدمة بـ TypeScript لتبيين أنواع خاطئة واستدعاءات دوال غير سليمة وحقول ناقصة. تظهر المشاكل قبل التشغيل، وهذا الأهم كلما كبر التطبيق وتكثَّف العمل الجماعي.

مع الأنواع والأدوات، تصبح الهيكلة أوضح وأسهل صيانة. القسميات التالية تلخص الصفات والانتشار ومقارنة مع لغات أخرى وتفاصيل تصنيف واضحة (نموذج الأنواع، دعم البرمجة كائنية التوجّه، مستوى التجريد، وكيف تُصرَّف وتُنفَّذ الشيفرة).

الصفات التي تميّز TypeScript

يعرف TypeScript بهيكل يمكن التنبؤ به وبأدوات تتوسع مع حجم الفريق والمشروع.

  • أنواع ساكنة اختيارية: يُضيف المطوّر الأنواع حيث تفيد. يجري الفحص أثناء التحرير وعند البناء بدلاً من الانتظار لمفاجآت وقت التشغيل الصامتة.
  • استنتاج الأنواع: يستخلص المحلّل أنواعاً كثيرة من القيم ومسارات الإرجاع، فيقلّ التكرار المزعوم مقارنة بكتابة كل متغير يدوياً.
  • الواجهات وألقاب الأنواع: تبقى أشكال البيانات والعقود صريحة ليتشارك الفريق نفس الصورة عن واجهات البرمجة والنماذج.
  • الصفوف والأنواع العامة (generics): أنماط كائنية التوجّه وتجريدات قابلة لإعادة الاستخدام تبقى دعماً أولاً للمكتبات والأطر.
  • التكامل مع JavaScript: المكتبات الحالية تعمل عبر أنواع تغليف أو تعريفات أكثر مرونة، ما يُبقي اعتماد TypeScript تدريجياً عملياً.
  • تكامل جيد مع المحرّر: الإكمال التلقائي وإعادة الهيكلة الآمنة والتلميحات داخل المحرّر تعكس معرفة دقيقة بالأنواع.

هذا المقتطف يُظهر بياناً مكتوباً إلى جانب منطق بأسلوب JavaScript عادي. يفهم المحلّل شكل Book ونوع إرجاع formatTitle:

type Book = {
  title: string;
  year: number;
};

function formatTitle(book: Book): string {
  return `${book.title} (${book.year})`;
}

console.log(formatTitle({ title: "Zero to One", year: 1962 }));

إن أُرسِل إلى formatTitle كائنٌ بدون الحقل year، أو وُضِعَت سلسلة نصّية حيث يُنتظر عدد، يُظهر TypeScript ذلك قبل وقت التشغيل.

جميع هذه الصفات معاً تقلّل العيوب، وتسرّع إعادة الهيكلة، وتساعد القواعد الكبيرة على البقاء متماسكة.

أين تُستخدم TypeScript في الواقع؟

TypeScript منتشر حيث يعمل JavaScript أصلاً، وفي فِرَق تحتاج تعاوناً ثابتاً.

تُقرَن المواقع الكبيرة وتطبيقات الصفحة الواحدة (SPA) غالباً بـ TypeScript إلى جانب React أو Angular أو Vue وأطر مثل Next.js أو Remix. تستخدمها فرق الواجهات الخلفية مع أطر Node.js مثل NestJS أو Express مع معالجات مكتوبة بأنواع. تطبيقات سطح المكتب بـ Electron وأدوات المطورين والإضافات على نمط VS Code تعتمد عليها أيضاً حيث يهم الحجم وسلامة إعادة الهيكلة.

أمثلة ملموسة:

  • لوحات معلومات داخلية وبوابات عملاء لمزودي خدمات سحابية (مثل Shopify تنشر تجارب هندسية ثقيلة على TypeScript).
  • Microsoft تصدر لغة TypeScript نفسها وتستخدمها عبر المواقع والأدوات.
  • شركات مثل Airbnb وSlack تحدّث أيضاً عن استخدام واسع لـ TypeScript ضمن منتجات ويب (سياسات التوثيق تتغير، غير أن الاتجاه في المنظومة نحو واجهات مكتوبة بنوعية قوية واضح).

باختصار: الفِرَق المعتمدة على قواعد JavaScript المتنامية تتبنى TypeScript عندما يتجاوز التعقيد والتعاون وتكلفة الصيانة طويلة الأمد الاستثمار الأولي.

كيف تختلف TypeScript عن لغات أخرى

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

الموضوعTypeScriptJavaScriptPythonJava
فحوصات ساكنة قبل التشغيلنعم، عبر المُصرِّف والمحرّرلا مرحلة ساكنة للغة ككل؛ الأنواع ظاهرة وقت التشغيل فقطاختيارية، مع أدوات منفصلة (منها فاحصو أنواع)نعم، عند التصرّيف
المسار الافتراضي لشيفرة SPA في المتصفحتحويل (transpile) إلى JavaScriptكتابة JavaScript مباشرةليس غالباً المسار المعتمد للإنتاجليس غالباً المسار المعتمد للإنتاج
أسلوب أنواع القيمأنواع هيكلية مع صفوفكائنات ديناميكيةقيم ديناميكية؛ إيضاحات اختياريةغالباً صفوف/واجهات إسمانية
بيئة تشغيل مُدارَة للنشرالمتصفح أو Node عبر JavaScript المنبثقVM المتصفح أو NodeCPython أو أجهزة افتراضية أخرىبايت كود JVM

TypeScript على منصّة JavaScript: يبقى هدف النشر واحداً وتُزاد خطوة فحص وصياغة أنواع أغنى قبل شحن JavaScript. Java وPython تتفوقان على أجهزة افتراضية وأدواتهما. مزيج TypeScript المميز هو كتابة مكتوبة الأنواع لعالم NPM والمتصفح، وليست بديلاً عن تلك المنصات.

TypeScript بعبارات بسيطة

كتابة ساكنة أم ديناميكية؟

ساكنة في الممارسة. يفحص TypeScript الأنواع قبل أن يعمل JavaScript المُنشَأ. يبقى السلوك وقت التشغيل JavaScript ديناميكياً بعد النشر؛ غير أن كتابة TypeScript تعني اعتبار إشارات ما قبل وقت التشغيل القاعدة. ثغرات (any) تبقى ممكنة، لكن الفرق المنهجية تقيِّد استخدامها لأن القيمة الحقيقية للغة تكمن في قيود قابلة للتنبؤ.

دعم البرمجة كائنية التوجّه؟

نعم. صفوف مع وراثة (extends)، ومعدّلات وصول (private, public، …)، وواجهات تصف العقود، وأنماط مثل الأنواع العامة تُظهر تأثراً كائني التوجّه مباشرة. يجمع هذا النموذج بين الكتابة الهيكلية والأسمائية، ما يُبقي العمل الكائني مناسباً.

لغة عالية المستوى؟

نعم. تخفي تفاصيل سجلات المعالج أو إدارة الذاكرة يدوياً. تربط المفاهيم بواجهات تطبيقات REST وسير عمل أعمال بدلاً بتعليمات معالج خام.

مُصرَّفة أم مفسَّرة؟

كلاهما مهم. يكتب المطوّر TypeScript، ومُصرِّف tsc (أو أدوات تجميع تستدعيه) يحوّل النص إلى JavaScript صريح. بعد التسليم، يعتمد المتصفح وNode على محركات JavaScript الناضجة (غالب JIT). وصف الصورة كلها كما ينطق عنها المتخصصون: «TypeScript يُصرَّف إلى JavaScript ثم تنفَّذ بواسطة محرّك JavaScript».

خلاصة

تشغّل JavaScript اليوم جزءاً كبيراً جداً من الويب وتعمل في جميع المتصفّحات الرئيسية تقريباً.

هذه الصورة لا تتبدّل: التطبيقات الجاهزة ما زالت ترسل على شكل JavaScript عادي. TypeScript يضيف شيفرة مكتوبة الأنواع وفحوصات قبل النشر؛ فيُكتَشَف الكثير من الأخطاء مبكراً وتبقى القواعد الكبيرة أسهل صيانة، بينما كل شيء يعمل على نفس محرّك JavaScript كما قبل.