استخدام Vue مع TypeScript
نظام الأنواع مثل TypeScript يمكنه اكتشاف العديد من الأخطاء الشائعة عبر التحليل الساكن في وقت البناء. هذا يقلل من فرصة الأخطاء في وقت التشغيل في مرحلة الإنتاج ، ويسمح لنا أيضًا بالتحكم بشكل أكثر تأكيدًا في إعادة تنظيم الشيفرة في التطبيقات الكبيرة. TypeScript يحسن أيضًا تركيز المطورين عبر الإكمال التلقائي المستند إلى النوع في محررات الشيفرات.
Vue مكتوب بلغة TypeScript ويوفر دعم TypeScript بدرجة أولى، جميع حزم Vue الرسمية تأتي مع تعريفات الأنواع المجمعة التي يجب أن تعمل بشكل مباشر.
إعداد المشروع
أداة create-vue
, هي أداة إنشاء المشاريع الرسمية ، تقدم خيارات لإنشاء مشروع Vue مع دعم Vite و TypeScript.
نظرة شاملة
مع الإعداد المعتمد على Vite ، يصرف خادم التطوير والمجمع فقط ولا تُنفذ أي عملية فحص للأنواع. هذا يضمن أن خادوم تطوير Vite يبقى سريعًا بشكل مذهل حتى عند استخدام TypeScript.
خلال عملية التطوير ، نوصي بالاعتماد على إعداد جيد للمحرر للحصول على ملاحظات فورية حول الأخطاء النوعية.
إذا كنت تستخدم SFC ، فاستخدم أداة
vue-tsc
للتحقق من الأنواع وإنشاء تعريفات الأنواع عبر سطر الأوامر.vue-tsc
هو عبارة عن متحكم في الأوامر ، وهو واجهة سطر الأوامر الخاصة بـ TypeScript. يعمل بشكل كبير على نفس الطريقة مثلtsc
باستثناء أنه يدعم SFC Vue بالإضافة إلى ملفات TypeScript. يمكنك تشغيلvue-tsc
في وضع مراقبة في الوقت نفسه مع خادوم تطوير Vite ، أو استخدام ملحق Vite مثل vite-plugin-checker الذي يقوم بتشغيل التحققات في موضع عمل منفصل.Vue CLI يوفر أيضًا دعم TypeScript ، ولكن لم يعد موصى به. اطلع على الملاحظات أدناه.
دعم محررات النصوص
Visual Studio Code (VSCode) موصى به بشدة لدعمه الرائع لـ TypeScript.
Volar هو ملحق VSCode الرسمي الذي يوفر دعم TypeScript داخل SFC Vue ، بالإضافة إلى العديد من الميزات الرائعة.
نصيحة
Volar يستبدل Vetur ، ملحق VSCode الرسمي السابق لـ Vue 2. إذا كنت تمتلك Vetur حاليًا ، تأكد من تعطيله في مشاريع Vue 3.
ملحق TypeScript Vue مطلوب أيضًا للحصول على دعم الأنواع للمستوردات
*.vue
في ملفات TS.
WebStorm يوفر أيضًا دعم TypeScript و Vue بشكل جاهز.محررات JetBrains الأخرى تدعمهم، إما بشكل جاهز أو عبر ملحق مجاني. As of version 2023.2, WebStorm and the Vue Plugin come with built-in support for the Vue Language Server. You can set the Vue service to use Volar integration on all TypeScript versions, under Settings > Languages & Frameworks > TypeScript > Vue. By default, Volar will be used for TypeScript versions 5.0 and higher.
إعداد tsconfig.json
المشاريع المنشأة عبر create-vue
تتضمن tsconfig.json
مُعد مسبقًا. يجرد الإعداد الأساسي في حزمة @vue/tsconfig
. داخل المشروع ، نستخدم مراجع المشروع لضمان الأنواع الصحيحة للشيفرة التي تعمل في بيئات مختلفة (على سبيل المثال ، يجب أن تكون الشيفرة الخاصة بالتطبيق والاختبار مختلفة في الحقول العامة).
عند إعداد tsconfig.json
يدويًا ، يتضمن بعض الخيارات الملحوظة:
compilerOptions.isolatedModules
مضبوط علىtrue
لأن Vite يستخدم esbuild لترجمة TypeScript ويعتمد على محدوديات الترجمة للملف الواحد.إذا كنت تستخدم واجهة الخيارات ، فيجب عليك تعيين
compilerOptions.strict
إلىtrue
(أو على الأقل تمكينcompilerOptions.noImplicitThis
، وهو جزء من العلمstrict
) لاستغلال التحقق من الأنواع لـthis
في خيارات المكون. وإلا ستُعامَلthis
كـany
.إذا قمت بإعداد الأسماء البديلة للمحلل في أداة البناء الخاصة بك ، على سبيل المثال الاسم البديل
*/@*
المعد افتراضيا في مشروعcreate-vue
، فيجب عليك أيضًا إعداده لـ TypeScript عبرcompilerOptions.paths
.
اطلع أيضا على:
وضع الاستحواذ لـ Volar
هذا القسم ينطبق فقط على VSCode + Volar.
من أجل جعل المكونات أحادية الملف وTypeScript تعمل معا ، ينشئ Volar نسخة من لغة TS منفصل مصحوبًا بدعم خاص بـVue ، ويستخدمه في المكونات أحادية الملف. في نفس الوقت ، تعالج ملفات TS العادية بواسطة خدمة TS الداخلية لـ VSCode ، وهذا هو السبب في أننا نحتاج ملحق TypeScript Vue لدعم استيرادات مكونات Vue أحادية الملف في ملفات TS. يعمل هذا الإعداد الافتراضي ، لكن لكل مشروع نحن نشغل نسختين من خدمة TS: واحد من Volar ، والآخر من خدمة VSCode الداخلية. هذا الأمر غير فعال ويمكن أن يؤدي إلى مشاكل أداء في المشاريع الكبيرة.
يوفر Volar ميزة تسمى "وضع الاستحواذ" لتحسين الأداء. في وضع الاستحواذ ، يوفر Volar دعمًا لكل من ملفات Vue و TS باستخدام نسخة واحدة من خدمة TS.
لتمكين وضع الاستحواذ ، يجب عليك تعطيل خدمة TS الداخلية لـ VSCode في مساحة العمل لمشروعك فقط باتباع الخطوات التالية:
- في مساحة العمل لمشروعك ، اظهر لوحة الأوامر باستخدام
Ctrl + Shift + P
(macOS:Cmd + Shift + P
). - اكتب
built
واختر "Extensions: Show Built-in Extensions". - اكتب
typescript
في مربع البحث عن الملحق (لا تزيل بادئة@builtin
). - انقر فوق رمز العجلة الصغيرة لـ "TypeScript and JavaScript Language Features" ، وحدد "Disable (Workspace)".
- إعادة تحميل مساحة العمل. سيمكن وضع الاستحواذ عند فتح ملف Vue أو TS.
ملاحظة بخصوص Vue CLI و ts-loader
في الإعدادات المستندة على webpack مثل Vue CLI ، من الشائع تنفيذ التحقق من النوع كجزء من سلسلة تحويل الوحدة ، على سبيل المثال مع ts-loader
. ومع ذلك ، ليس هذا حل نظيف لأن النظام النوعي يحتاج إلى معرفة كامل مخطط الوحدة لإجراء عمليات التحقق من النوع. لا تكون خطوة تحويل الوحدة الفردية مناسبة للمهمة. يؤدي ذلك إلى مشاكل التالية:
ts-loader
يمكنه فقط التحقق من النوع في الشيفرة بعد التحويل. لا يتوافق هذا مع الأخطاء التي نراها في المحرر أو منvue-tsc
، والتي تنعكس مباشرة على الشيفرة المصدرية.يمكن أن يكون التحقق من النوع بطيئًا. عندما يُجرى في نفس مسلك التنفيذ / العملية مع تحويلات الشيفرة ، فإنه يؤثر بشكل كبير على سرعة إنشاء التطبيق بأكمله.
لدينا التحقق من النوع يعمل بالفعل في محررنا في عملية منفصلة ، لذلك لا يوجد تكلفة لتأخير تجربة التطوير.
إذا كنت تستخدم حاليًا Vue 3 + TypeScript عبر Vue CLI ، فنحن ننصح بشدة بالترحيل إلى Vite. كما نعمل أيضًا على خيارات CLI لتمكين دعم TS transpile-only ، حتى تتمكن من التبديل إلى vue-tsc
للتحقق من النوع.
ملاحظات عامة عن الاستخدام
()defineComponent
لتمكين TypeScript من تحديد الأنواع بشكل صحيح داخل خيارات المكون ، نحتاج إلى تعريف المكونات باستخدام ()defineComponent
:
ts
import { defineComponent } from 'vue'
export default defineComponent({
// تمكين تحديد الأنواع
props: {
name: String,
msg: { type: String, required: true }
},
data() {
return {
count: 1
}
},
mounted() {
this.name // type: string | undefined
this.msg // type: string
this.count // type: number
}
})
تدعم الدالة ()defineComponent
أيضًا تحديد الخاصيات الممررة إلى setup()
عند استخدام الواجهة التركيبية بدون <script setup>
:
ts
import { defineComponent } from 'vue'
export default defineComponent({
// تمكين تحديد الأنواع
props: {
message: String
},
setup(props) {
props.message // type: string | undefined
}
})
اطلع أيضًا على:
نصيحة
تمكن الدالة ()defineComponent
أيضًا تحديد الأنواع للمكونات المعرفة في JavaScript العادي.
الاستخدام في المكونات أحادية الملف
لاستخدام TypeScript في المكونات أحادية الملف، أضف سمة "lang="ts
إلى وسوم <script>
. عندما يكون "lang="ts
موجودًا ، تتمتع جميع تعبيرات القالب أيضًا بالتحقق من النوع بشكل أكثر صرامة.
vue
<script lang="ts">
import { defineComponent } from 'vue'
export default defineComponent({
data() {
return {
count: 1
}
}
})
</script>
<template>
<!-- تمكين التحقق من الأنواع والإكمال التلقائي -->
{{ count.toFixed(2) }}
</template>
يمكن استخدام "lang="ts
أيضًا مع <script setup>
:
vue
<script setup lang="ts">
// تمكين TypeScript
import { ref } from 'vue'
const count = ref(1)
</script>
<template>
<!-- تمكين التحقق من الأنواع والإكمال التلقائي -->
{{ count.toFixed(2) }}
</template>
TypeScript في القوالب
عنصر القالب <template>
يدعم أيضًا TypeScript في تعبيرات الربط عند استخدام <"script lang="ts>
أو <"script setup lang="ts>
. هذا مفيد في حالات تحتاج فيها إلى تنفيذ تحويل الأنواع في تعبيرات القالب.
هنا مثال مزعج:
vue
<script setup lang="ts">
let x: string | number = 1
</script>
<template>
<!-- خطأ لأن x يمكن أن يكون سلسلة نصية -->
{{ x.toFixed(2) }}
</template>
يمكن تجاوز هذه المشكلة عن طريق التحويل السطري الأنواع :
vue
<script setup lang="ts">
let x: string | number = 1
</script>
<template>
{{ (x as number).toFixed(2) }}
</template>
نصيحة
إذا كنت تستخدم Vue CLI أو إعداد webpack ، فتتطلب تعبيرات TypeScript في القالب الاعتمادية vue-loader@^16.8.0
.
Usage with TSX
Vue also supports authoring components with JSX / TSX. Details are covered in the Render Function & JSX guide.
مكونات معممة
المكونات المعممة مدعومة في حالتين:
- في المكونات أحادية الملف SFC :
<script setup>
مع سمةgeneric
- دالة التصيير و JSX : مع بصمة الدالة
()defineComponent