الخيارات: التصيير
template
قالب المكون على شكل سلسلة نصية.
النوع
tsinterface ComponentOptions { template?: string }
التفاصيل
القالب المقدم عبر الخيار
template
سيُصير على الطائر أثناء التشغيل. هذا الخيار مدعوم فقط عند استخدام عملية بناء Vue الذي يتضمن مصرف القوالب. مصرف القوالب غير مدرج في بناء Vue الذي يحتوي على كلمةruntime
في أسمائه، على سبيل المثالvue.runtime.esm-bundler.js
. راجع دليل ملفات التوزيع لمزيد من التفاصيل حول مختلف عمليات البناء.إذا بدأت السلسلة النصية بـ
#
ستُستخدم كـquerySelector
واستخدامinnerHTML
للعنصر المحدد كسلسلة نصية للقالب. هذا يسمح بكتابة القالب الأصلي باستخدام عناصر<template>
الأصلية.إذا كان الخيار
render
موجود أيضًا في نفس المكون، سيتم تجاهل خيارtemplate
.إذا لم يكن لدى المكون الجذر لتطبيقك خيار
template
أوrender
محدد، سيحاول Vue استخدامinnerHTML
للعنصر المركب كقالب بدلاً من ذلك.ملاحظة أمان
استخدم فقط مصادر القوالب التي يمكنك الوثوق بها. لا تستخدم محتوى المستخدم المقدم كقالب. راجع دليل الأمان لمزيد من التفاصيل.
render
دالة تعيد برمجيًا الشجرة DOM الافتراضية للمكون.
النوع
tsinterface ComponentOptions { render?(this: ComponentPublicInstance) => VNodeChild } type VNodeChild = VNodeChildAtom | VNodeArrayChildren type VNodeChildAtom = | VNode | string | number | boolean | null | undefined | void type VNodeArrayChildren = (VNodeArrayChildren | VNodeChildAtom)[]
التفاصيل
render
هو بديل لقوالب السلسلة النصية التي تسمح لك بالاستفادة من القوة البرمجية الكاملة لـ JavaScript للتصريح بمخرجات تصيير المكون.القوالب المصرفة مسبقًا، على سبيل المثال تلك الموجودة في مكونات الملف الواحد، تصرف إلى خيار
render
أثناء عملية البناء. إذا كان كل منrender
وtemplate
موجودين في مكون، سيأخذrender
أولوية أعلى. Render Functionsاطلع أيضًا على
compilerOptions
تقوم بإعداد خيارات مصرف التشغيل لقالب المكون.
النوع
tsinterface ComponentOptions { compilerOptions?: { isCustomElement?: (tag: string) => boolean whitespace?: 'condense' | 'preserve' // default: 'condense' delimiters?: [string, string] // default: ['{{', '}}'] comments?: boolean // default: false } }
التفاصيل
هذا الخيار لا يؤخذ بعين الاعتبار إلا عند استخدام عملية بناء كاملة (أي
vue.js
المستقل الذي يمكنه تصريف القوالب في المتصفح). يدعم نفس الخيارات كـ app.config.compilerOptions على مستوى جذر التطبيق، وله أولوية أعلى للمكون الحالياطلع أيضًا على app.config.compilerOptions
slots
- Only supported in 3.3+
خيار للمساعدة في استنتاج النوع عند استخدام المنافذ برمجيًا في دوال التصيير. مدعوم فقط في 3.3+.
التفاصيل
قيمة هذا الخيار في وقت التشغيل لا تستخدم. يجب أن تُعلن الأنواع الفعلية باستخدام تحويل النوع باستخدام دالة النوع المساعدة
SlotsType
:tsimport { SlotsType } from 'vue' defineComponent({ slots: Object as SlotsType<{ default: { foo: string; bar: number } item: { data: number } }>, setup(props, { slots }) { expectType< undefined | ((scope: { foo: string; bar: number }) => any) >(slots.default) expectType<undefined | ((scope: { data: number }) => any)>( slots.item ) } })