الواجهة البرمجية لدالة التخريج
()h
تنشئ عقد DOM افتراضية (vnodes).
النوع
ts// البصمة الكاملة function h( type: string | Component, props?: object | null, children?: Children | Slot | Slots ): VNode // حذف الخاصيات function h(type: string | Component, children?: Children | Slot): VNode type Children = string | number | boolean | VNode | null | Children[] type Slot = () => Children type Slots = { [name: string]: Slot }
الأنواع مبسطة لتسهيل القراءة.
التفاصيل
الوسيط الأول يمكن أن يكون سلسلة نصية (للعناصر الأصلية) أو تعريف مكون Vue. الوسيط الثاني هو الخاصيات التي ستُمرر ، والوسيط الثالث هو المكونات الأبناء.
عند إنشاء عقد المكون ، يجب تمرير الأبناء كدوال منفذ. يمكن تمرير دالة منفذ واحدة إذا كان المكون يتوقع فقط منفذ افتراضي. وإلا ، يجب تمرير المنافذ ككائن من دوال المنافذ.
للتسهيل ، يمكن حذف وسيط الخاصيات عندما لا تكون المكونات الأبناء عبارة عن كائن منافذ.
مثال
إنشاء عناصر أصلية:
jsimport { h } from 'vue' // جميع الوسائط ما عدا النوع اختيارية h('div') h('div', { id: 'foo' }) // يمكن استخدام السمات والخاصيات في كائن الخاصيات // يختار Vue تلقائيًا الطريقة الصحيحة لتعيينها h('div', { class: 'bar', innerHTML: 'hello' }) // الفئة والنمط لديهما نفس قيمة دعم // الكائن / مصفوفة مثل القوالب h('div', { class: [foo, { bar }], style: { color: 'red' } }) // يجب تمرير مستمعي الأحداث كـ onXxx h('div', { onClick: () => {} }) // يمكن أن تكون المكونات الأبناء سلسلة نصية h('div', { id: 'foo' }, 'hello') // يمكن حذف كائن الخاصيات عندما لا تكون هناك خاصيات h('div', 'hello') h('div', [h('span', 'hello')]) // مصفوفة الأبناء يمكن أن تحتوي على عقد افتراضية وسلاسل مختلطة h('div', ['hello', h('span', 'hello')])
إنشاء المكونات:
jsimport Foo from './Foo.vue' // تمرير الخاصيات h(Foo, { // ما يعادل some-prop="مرحبا" someProp: 'مرحبا', // ما يعادل @update="() => {}" onUpdate: () => {} }) // تمرير منفذ افتراضي واحد h(Foo, () => 'default slot') // تمرير منافذ مسماة // لاحظ أنه يتطلب `null` لتجنب // يتم التعامل مع كائن المنافذ كخاصيات h(MyComponent, null, { default: () => 'default slot', foo: () => h('div', 'foo'), bar: () => [h('span', 'one'), h('span', 'two')] })
اطلع أيضاً دليل دوال التخريج - إنشاء عقد VNodes
()mergeProps
دمج عدة كائنات خاصيات مع معالجة خاصة لبعض الخاصيات.
النوع
tsfunction mergeProps(...args: object[]): object
التفاصيل
mergeProps()
يدعم دمج عدة كائنات خاصيات مع معالجة خاصة للخاصيات التالية:class
style
onXxx
مستمعي الأحداث - ستُدمج المستمعات المتعددة بنفس الاسم في مصفوفة.
إذا لم تكن بحاجة إلى سلوك الدمج وتريد استبدالات بسيطة ، فيمكن استخدام طريقة نشر الكائن الأصلية بدلاً من ذلك.
Example
jsimport { mergeProps } from 'vue' const one = { class: 'foo', onClick: handlerA } const two = { class: { bar: true }, onClick: handlerB } const merged = mergeProps(one, two) /** { class: 'foo bar', onClick: [handlerA, handlerB] } */
()cloneVNode
تستنسخ عقدة افتراضية.
النوع
tsfunction cloneVNode(vnode: VNode, extraProps?: object): VNode
التفاصيل
يعيد عقدة افتراضية مستنسخة ، اختياريًا مع خاصيات إضافية لدمجها مع الأصل.
يجب اعتبار العقد الافتراضية غير قابلة للتغيير بمجرد إنشائها ، ولا يجب تغيير خاصيات عقدة افتراضية موجودة. بدلاً من ذلك ، استنسخها مع خاصيات مختلفة / إضافية.
العقد الافتراضية لها خاصيات داخلية خاصة ، لذلك لا يكون استنساخها بسيطًا مثل نشر الكائن.
()cloneVNode
يتعامل مع معظم المنطق الداخلي.مثال
jsimport { h, cloneVNode } from 'vue' const original = h('div') const cloned = cloneVNode(original, { id: 'foo' })
()isVNode
تحقق مما إذا كانت القيمة عبارة عن عقدة افتراضية.
النوع
tsfunction isVNode(value: unknown): boolean
()resolveComponent
لاستبيان المكون المسجل يدويًا بالاسم.
النوع
tsfunction resolveComponent(name: string): Component | string
التفاصيل
ملاحظة: لا تحتاج إلى ذلك إذا كنت تستطيع استيراد المكون مباشرة.
يجب استدعاء
()resolveComponent
إما داخل()setup
أو دالة التخريج من أجل استبيان سياق المكون الصحيح.إذا لم يعثر على المكون ، فسيصدَر تحذير في وقت التشغيل ، ويرجع السلسلة النصية للاسم.
مثال
jsimport { h, resolveComponent } from 'vue' export default { setup() { const ButtonCounter = resolveComponent('ButtonCounter') return () => { return h(ButtonCounter) } } }
اطلع أيضاً دليل دوال التخريج - المكونات
()resolveDirective
لاستبيان السمة الموجهة المسجلة يدويًا بالاسم.
النوع
tsfunction resolveDirective(name: string): Directive | undefined
النوع
ملاحظة: لا تحتاج إلى ذلك إذا كنت تستطيع استيراد السمة الموجهة مباشرة.
يجب استدعاء
()resolveDirective
إما داخل()setup
أو دالة التخريج من أجل استبيان سياق المكون الصحيح.إذا لم يعثر على السمة الموجهة ، فسيصدَر تحذير في وقت التشغيل ، وتعيد الدالة القيمة
undefined
.اطلع أيضاً دليل دوال التخريج - السمات الموجهة المخصصة
()withDirectives
لاضافة السمات الموجهة المخصصة إلى العقد الافتراضية.
النوع
tsfunction withDirectives( vnode: VNode, directives: DirectiveArguments ): VNode // [Directive, value, argument, modifiers] type DirectiveArguments = Array< | [Directive] | [Directive, any] | [Directive, any, string] | [Directive, any, string, DirectiveModifiers] >
التفاصيل
تلف العقدة الافتراضية الموجودة بالسمات الموجهة المخصصة. الوسيط الثاني هو مصفوفة من السمات الموجهة المخصصة. تُمثَّل كل سمة موجهة مخصصة أيضًا كمصفوفة على شكل
[Directive, value, argument, modifiers]
. يمكن حذف العناصر التذييلية من المصفوفة إذا لم يكن هناك حاجة إليها.مثال
jsimport { h, withDirectives } from 'vue' // سمة موجهة مخصصة const pin = { mounted() { /* ... */ }, updated() { /* ... */ } } // <div v-pin:top.animate="200"></div> const vnode = withDirectives(h('div'), [ [pin, 200, 'top', { animate: true }] ])
اطلع أيضاً دليل دوال التخريج - السمات الموجهة المخصصة
()withModifiers
لاضافة المعدلات المدمجة v-on
إلى دالة معالج الحدث.
النوع
tsfunction withModifiers(fn: Function, modifiers: ModifierGuardsKeys[]): Function
مثال
jsimport { h, withModifiers } from 'vue' const vnode = h('button', { // ما يعادل v-on:click.stop.prevent onClick: withModifiers(() => { // ... }, ['stop', 'prevent']) })
اطلع أيضاً دليل دوال التخريج - معدلات الأحداث