Heim  >  Artikel  >  Web-Frontend  >  Was ist ein Slot? Ein genauerer Blick auf Slots in Vue

Was ist ein Slot? Ein genauerer Blick auf Slots in Vue

青灯夜游
青灯夜游nach vorne
2022-06-01 13:00:116806Durchsuche

Was ist ein Slot? In diesem Artikel erfahren Sie mehr über die Slots, die für den Einstieg in Vue unerlässlich sind, erfahren die grundlegende Verwendung von Slots und stellen benannte Slots und Scope-Slots vor. Ich hoffe, dass er für alle hilfreich ist!

Was ist ein Slot? Ein genauerer Blick auf Slots in Vue

1. Was ist ein Slot? Ermöglicht Entwicklern die Definition von „unsicheren Teilen“, von denen erwartet wird, dass sie vom Benutzer beim Verpacken von Komponenten als Steckplätze angegeben werden. Slots können als Platzhalter für Inhalte betrachtet werden, die während der Komponentenkapselung für Benutzer reserviert sind. (Lernvideo-Sharing: vue-Video-Tutorial

)

2. Erleben Sie die grundlegende Verwendung von SlotsBeim Kapseln von Komponenten können Sie

<slot></slot>

übergeben Elemente definieren Slots und reservieren dadurch Inhaltsplatzhalter Was ist ein Slot? Ein genauerer Blick auf Slots in Vue für den Benutzer. Der Beispielcode lautet wie folgt:

Bildbeschreibung hier einfügen

2.1 Inhalte ohne reservierte Slots werden verworfen

Wenn

beim Packen einer Komponente keine <slot></slot>-Slots reserviert sind, werden alle vom Benutzer bereitgestellten <slot></slot> 元素定义插槽,从而为用户预留内容占位符。示例代码如下:
Was ist ein Slot? Ein genauerer Blick auf Slots in Vue

2.1 没有预留插槽的内容会被丢弃

如果在封装组件时没有预留任何 <slot></slot> 插槽,则用户提供的任何自定义内容都会被丢弃。示例代码如下:
Was ist ein Slot? Ein genauerer Blick auf Slots in Vue

2.2 后备内容

封装组件时,可以为预留的 <slot></slot> 插槽提供后备内容(默认内容)。如果组件的使用者没有为插槽提供任何内容,则后备内容会生效。示例代码如下:
Was ist ein Slot? Ein genauerer Blick auf Slots in Vue

3、具名插槽

如果在封装组件时需要预留多个插槽节点,则需要为每个 <slot></slot> 插槽指定具体的 name 名称。这种带有具体名称的插槽叫做“具名插槽”。示例代码如下:
Was ist ein Slot? Ein genauerer Blick auf Slots in Vue

温馨提醒:没有指定 name 名称的插槽,会有隐含的名称叫做 “default”。

3.1 为具名插槽提供内容

在向具名插槽提供内容的时候,我们可以在一个 <template></template> 元素上使用 v-slot 指令,并以 v-slot 的参数的形式提供其名称。示例代码如下:
Was ist ein Slot? Ein genauerer Blick auf Slots in Vue

3.2 具名插槽的简写形式

跟 v-on 和 v-bind 一样,v-slot 也有缩写,即把参数之前的所有内容 (v-slot:) 替换为字符 #。例如 v-slot:header
可以被重写为 #header:
Was ist ein Slot? Ein genauerer Blick auf Slots in Vue

4、作用域插槽

在封装组件的过程中,可以为预留的 <slot></slot> 插槽绑定 props 数据,这种带有 props 数据的 <slot></slot> 叫做“作用域插槽”。示例代码如下:
Was ist ein Slot? Ein genauerer Blick auf Slots in Vue

4.1 使用作用域插槽

可以使用 v-slot:benutzerdefinierten Inhalte verworfen. Verwerfen
. Der Beispielcode lautet wie folgt: Was ist ein Slot? Ein genauerer Blick auf Slots in VueBildbeschreibung hier einfügen

2.2 Fallback-Inhalt

🎜Beim Kapseln einer Komponente können Sie 🎜Fallback-Inhalt🎜 (Standardinhalt) für den reservierten <slot></slot>-Slot bereitstellen. Wenn der Konsument der Komponente keinen Inhalt für den Slot bereitstellt, greift der Fallback-Inhalt. Der Beispielcode lautet wie folgt: 🎜Bildbeschreibung hier einfügen🎜 🎜🎜 🎜3. Benannte Slots🎜🎜🎜🎜Wenn Sie beim Verpacken von Komponenten mehrere Slot-Knoten reservieren müssen, müssen Sie für jeden <slot></slot>-Slot einen bestimmten Namen angeben. Solche 🎜Slots mit bestimmten Namen werden „benannte Slots“ 🎜 genannt. Der Beispielcode lautet wie folgt: 🎜Bildbeschreibung hier einfügen🎜 🎜Warme Erinnerung: Slots ohne angegebenen Namen haben einen impliziten Namen namens „default“. 🎜🎜🎜3.1 Inhalte für den benannten Slot bereitstellen 🎜🎜🎜Bei der Bereitstellung von Inhalten für den benannten Slot können wir 🎜v-slot auf einem <template></template> Elementcode>🎜 verwenden Direktive, die ihren Namen als Argument für 🎜v-slot🎜 bereitstellt. Der Beispielcode lautet wie folgt: 🎜Bildbeschreibung hier einfügen🎜 🎜🎜 3.2 Die Abkürzung des benannten Slots🎜🎜🎜Wie v-on und v-bind hat auch v-slot eine Abkürzung, dh der gesamte Inhalt vor dem Parameter (v-slot :) wird durch die Zeichen ersetzt # . Beispielsweise kann v-slot:header🎜 als #header umgeschrieben werden: 🎜 Hier Bildbeschreibung einfügen🎜🎜🎜🎜4. Scope-Slots🎜🎜🎜🎜Beim Einkapseln von Komponenten können Sie die reservierten <slot></slot> Slotpropsbinden > Daten, diese Art von <slot></slot> mit Requisitendaten wird „Scope-Slot“ genannt 🎜. Der Beispielcode lautet wie folgt: 🎜Bildbeschreibung hier einfügen🎜 🎜🎜 4.1 Verwendung von Scope-Slots🎜🎜🎜Sie können die Form von v-slot: verwenden, um die vom Scope-Slot bereitgestellten Daten zu empfangen. Der Beispielcode lautet wie folgt: 🎜🎜🎜🎜🎜4.2 Slot Prop dekonstruieren🎜🎜

Die vom Scope-Slot bereitgestellten Datenobjekte können verwendet werden, um den Datenempfangsprozess mithilfe der destrukturierenden Zuweisung zu vereinfachen. Der Beispielcode lautet wie folgt:
Was ist ein Slot? Ein genauerer Blick auf Slots in Vue

(Lernvideo-Sharing: Web-Front-End-Entwicklung, Grundlegendes Programmiervideo)

Das obige ist der detaillierte Inhalt vonWas ist ein Slot? Ein genauerer Blick auf Slots in Vue. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:csdn.net. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen