Inhaltsverzeichnis
Vues offizielle Definition von Slots
Slot到底是什么
如何使用插槽
回顾组件渲染的原理
插槽的初始化原理
解析插槽中的内容
作用域插槽原理
header
具名插槽原理
默认内容插槽的原理
Heim Web-Frontend View.js Was ist das Implementierungsprinzip des Vue3-Slot-Slots?

Was ist das Implementierungsprinzip des Vue3-Slot-Slots?

May 24, 2023 am 09:28 AM
vue3 slot

Vues offizielle Definition von Slots

Vue implementiert eine Reihe von APIs zur Inhaltsverteilung. Das Design dieser API ist vom Entwurf der Web Components-Spezifikation inspiriert und verwendet das Element <slot></slot> als Träger für die Verteilung Inhalt exportieren. <slot></slot> 元素作为承载分发内容的出口。

Slot到底是什么

那么Slot到底是什么呢?Slot其实是一个接受父组件传过来的插槽内容,然后生成VNode并返回的函数。

我们一般是使用 <slot></slot> 这对标签进行接受父组件传过来的内容,那么这对标签最终编译之后是一个创建VNode的函数,我们可以叫做创建插槽VNode的函数。

// <slot></slot>标签被vue3编译之后的内容
export function render(_ctx, _cache, $props, $setup, $data, $options) {
  return _renderSlot(_ctx.$slots, "default")
}
Nach dem Login kopieren

我们可以清楚看到<slot></slot>标签被Vue3编译之后的就变成了一个叫_renderSlot的函数。

如何使用插槽

要使用插槽那就必须存在父子组件。

假设父组件为一下内容:

<todo-button>
  Add todo
</todo-button>
Nach dem Login kopieren

我们在父组件使用了一个todo-button的子组件,并且传递了Add todo的插槽内容。

todo-button子组件模版内容

<button class="btn-primary">
  <slot></slot>
</button>
Nach dem Login kopieren

当组件渲染的时候,<slot></slot> 将会被替换为“Add todo”。

回顾组件渲染的原理

那么这其中底层的原理是什么呢?在理解插槽的底层原理之前,我们还需要回顾一下Vue3的组件运行原理。

组件的核心是它能够产出一坨VNode。对于 Vue 来说一个组件的核心就是它的渲染函数,组件的挂载本质就是执行渲染函数并得到要渲染的VNode,至于什么data/props/computed 这都是为渲染函数产出 VNode 过程中提供数据来源服务的,最关键的就是组件最终产出的VNode,因为这个才是需要渲染的内容。

插槽的初始化原理

当Vue3遇到VNode类型为组件时,会进入组件渲染流程。组件渲染的流程就是首先创建组件实例,然后初始化组件实例,在初始化组件实例的时候就会去处理Slot相关的内容。

在源码的runtime-coresrccomponent.ts里面

Was ist das Implementierungsprinzip des Vue3-Slot-Slots?

在函数initSlots里面初始化组件Slot的相关内容

那么initSlots函数长啥样,都干了些什么呢?

runtime-coresrccomponentSlots.ts

Was ist das Implementierungsprinzip des Vue3-Slot-Slots?

首先要判断该组件是不是Slot组件,那么怎么判断该组件是不是Slot组件呢?我们先要回去看一下上面父组件编译之后的代码:

export function render(_ctx, _cache, $props, $setup, $data, $options) {
  const _component_todo_button = _resolveComponent("todo-button")
  return (_openBlock(), _createBlock(_component_todo_button, null, {
    default: _withCtx(() => [
      _createTextVNode(" Add todo ")
    ], undefined, true),
    _: 1 /* STABLE */
  }))
}
Nach dem Login kopieren

我们可以看到Slot组件的children内容是一个Object类型,也就是下面这段代码:

{
    default: _withCtx(() => [
      _createTextVNode(" Add todo ")
    ], undefined, true),
    _: 1 /* STABLE */
}
Nach dem Login kopieren

那么在创建这个组件的VNode的时候,就会去判断它的children是不是Object类型,如果是Object类型那么就往该组件的VNode的shapeFlag上挂上一个Slot组件的标记。

如果是通过模板编译过来的那么就是标准的插槽children,是带有_属性的,是可以直接放在组件实例上的slots属性。

如果是用户自己写的插槽对象,那么就没有_属性,那么就需要进行规范化处理,走normalizeObjectSlots

如果用户搞骚操作不按规范走,那么就走normalizeVNodeSlots流程。

解析插槽中的内容

我们先看看子组件编译之后的代码:

export function render(_ctx, _cache, $props, $setup, $data, $options) {
  return (_openBlock(), _createElementBlock("button", { class: "btn-primary" }, [
    _renderSlot(_ctx.$slots, "default")
  ]))
}
Nach dem Login kopieren

上面我们也讲过了<slot></slot>标签被vue3编译之后的就变成了一个叫_renderSlot的函数。

Was ist das Implementierungsprinzip des Vue3-Slot-Slots?

renderSlot函数接受五个参数,第一个是实例上的插槽函数对象slots,第二个是插槽的名字,也就是将插槽内容渲染到指定位置 ,第三个是插槽作用域接收的props,第四个是插槽的默认内容渲染函数,第五个暂不太清楚什么意思。

作用域插槽原理

作用域插槽是一种子组件传父组件的传参的方式,让插槽内容能够访问子组件中才有的数据 。

子组件模板

<slot username="coboy"></slot>
Nach dem Login kopieren

编译后的代码

export function render(_ctx, _cache, $props, $setup, $data, $options) {
  return _renderSlot(_ctx.$slots, "default", { username: "coboy" })
}
Nach dem Login kopieren

父组件模板

<todo-button>
    <template v-slot:default="slotProps">
        {{ slotProps.username }}
    </template>
</todo-button>
Nach dem Login kopieren

编译后的代码

export function render(_ctx, _cache, $props, $setup, $data, $options) {
  const _component_todo_button = _resolveComponent("todo-button")
  return (_openBlock(), _createBlock(_component_todo_button, null, {
    default: _withCtx((slotProps) => [
      _createTextVNode(_toDisplayString(slotProps.username), 1 /* TEXT */)
    ]),
    _: 1 /* STABLE */
  }))
}
Nach dem Login kopieren

上面讲过renderSlot函数,可以简单概括成下面的代码

export function renderSlots(slots, name, props) {
  const slot = slots[name]
  if (slot) {
    if (typeof slot === &#39;function&#39;) {
      return createVNode(Fragment, {}, slot(props))
    }
  }
}
Nach dem Login kopieren

slots

Was genau ist Slot?

Was genau ist Slot? Slot ist eigentlich eine Funktion, die den von der übergeordneten Komponente übergebenen Slot-Inhalt akzeptiert, dann einen VNode generiert und ihn zurückgibt.

Wir verwenden normalerweise <slot></slot>, um den von der übergeordneten Komponente übergebenen Inhalt zu akzeptieren. Nach der endgültigen Kompilierung dieses Tag-Paares wird es eine Funktion sein, die VNode erstellt . Wir können die Funktion aufrufen, die den Slot-VNode erstellt. 🎜
{
    default: _withCtx((slotProps) => [
      _createTextVNode(_toDisplayString(slotProps.username), 1 /* TEXT */)
    ]),
    _: 1 /* STABLE */
}
Nach dem Login kopieren
🎜Wir können deutlich sehen, dass das <slot></slot>-Tag nach der Kompilierung durch Vue3 zu einer Funktion namens _renderSlot wird. 🎜🎜So verwenden Sie Slots🎜🎜Um Slots zu verwenden, müssen Eltern-Kind-Komponenten vorhanden sein. 🎜🎜Angenommen, die übergeordnete Komponente hat den folgenden Inhalt: 🎜
_withCtx((slotProps) => [
      _createTextVNode(_toDisplayString(slotProps.username), 1 /* TEXT */)
])
Nach dem Login kopieren
🎜 Wir verwenden eine untergeordnete Komponente von todo-button in der übergeordneten Komponente und übergeben den Slot-Inhalt von Add todo. 🎜🎜Todo-Button-Unterkomponenten-Vorlageninhalt🎜
<div class="container">
  <header>
    <!-- 我们希望把页头放这里 -->
  </header>
  <main>
    <!-- 我们希望把主要内容放这里 -->
  </main>
  <footer>
    <!-- 我们希望把页脚放这里 -->
  </footer>
</div>
Nach dem Login kopieren
Nach dem Login kopieren
🎜Wenn die Komponente gerendert wird, wird <slot></slot> durch „Aufgabe hinzufügen“ ersetzt. 🎜🎜Überprüfung der Prinzipien des Komponenten-Renderings🎜🎜Was ist also das zugrunde liegende Prinzip? Bevor wir die zugrunde liegenden Prinzipien von Slots verstehen, müssen wir auch die Funktionsprinzipien der Vue3-Komponenten überprüfen. 🎜🎜Der Kern der Komponente besteht darin, dass sie eine Menge VNode erzeugen kann. Für Vue ist der Kern einer Komponente ihre Rendering-Funktion. Das Wesentliche beim Mounten einer Komponente besteht darin, die Rendering-Funktion auszuführen und den zu rendernden VNode zu erhalten. Diese dienen alle der Bereitstellung von Daten für das Rendering Funktion zum Generieren von VNode. Das Wichtigste am Quelldienst ist der VNode, der letztendlich von der Komponente erzeugt wird, da dies der Inhalt ist, der gerendert werden muss. 🎜🎜Initialisierungsprinzip des Slots🎜🎜Wenn Vue3 auf eine Komponente vom Typ VNode trifft, tritt es in den Komponenten-Rendering-Prozess ein. Der Prozess des Komponentenrenderings besteht darin, zunächst eine Komponenteninstanz zu erstellen und dann die Komponenteninstanz zu initialisieren. Beim Initialisieren der Komponenteninstanz werden Slot-bezogene Inhalte verarbeitet. 🎜🎜Im runtime-coresrccomponent.ts des Quellcodes🎜🎜Vue3 Slot Slot Was ist das Implementierungsprinzip? 🎜🎜runtime-coresrccomponentSlots.ts🎜🎜<img src=🎜🎜Zuerst müssen wir feststellen, ob die Komponente eine Slot-Komponente ist. Wie kann man also feststellen, ob die Komponente eine Slot-Komponente ist? Wir müssen zunächst zurückgehen und einen Blick auf den kompilierten Code der übergeordneten Komponente oben werfen: 🎜
<!--子组件-->
<div class="container">
  <header>
    <slot name="header"></slot>
  </header>
  <main>
    <slot></slot>
  </main>
  <footer>
    <slot name="footer"></slot>
  </footer>
</div>
Nach dem Login kopieren
Nach dem Login kopieren
🎜 Wir können sehen, dass der untergeordnete Inhalt der Slot-Komponente ein Objekttyp ist, bei dem es sich um den folgenden Code handelt: 🎜
<!--父组件-->
<base-layout>
  <template v-slot:header>
    <h2 id="header">header</h2>
  </template>
  <template v-slot:default>
    <p>default</p>
  </template>
  <template v-slot:footer>
    <p>footer</p>
  </template>
</base-layout>
Nach dem Login kopieren
Nach dem Login kopieren
🎜 Dann wann Beim Erstellen des VNode dieser Komponente wird ermittelt, ob seine untergeordneten Knoten vom Typ Object sind. Wenn es vom Typ Object ist, hängen Sie eine Slot-Komponentenmarkierung an das ShapeFlag des VNode der Komponente. 🎜🎜Wenn es über eine Vorlage kompiliert wird, handelt es sich um ein untergeordnetes Standard-Slot mit dem Attribut _, dem Attribut slots, das direkt auf der Komponenteninstanz platziert werden kann . 🎜🎜Wenn das Slot-Objekt vom Benutzer selbst geschrieben wird, verfügt es nicht über das Attribut _ und muss daher mit normalizeObjectSlots normalisiert werden. 🎜🎜Wenn der problematische Vorgang des Benutzers nicht den Spezifikationen entspricht, folgen Sie dem Prozess normalizeVNodeSlots. 🎜🎜Parsen Sie den Inhalt im Slot🎜🎜Sehen wir uns zunächst den kompilierten Code der Unterkomponente an:🎜
export function render(_ctx, _cache, $props, $setup, $data, $options) {
  const _component_base_layout = _resolveComponent("base-layout")
  return (_openBlock(), _createBlock(_component_base_layout, null, {
    header: _withCtx(() => [
      _createElementVNode("h2", null, "header")
    ]),
    default: _withCtx(() => [
      _createElementVNode("p", null, "default")
    ]),
    footer: _withCtx(() => [
      _createElementVNode("p", null, "footer")
    ]),
    _: 1 /* STABLE */
  }))
}
Nach dem Login kopieren
Nach dem Login kopieren
🎜Wir haben oben auch darüber gesprochen, dass das Tag <slot></slot> kompiliert wird von vue3 Danach wird es zu einer Funktion namens _renderSlot. 🎜🎜Was ist das Implementierungsprinzip von Vue3 Slot Slot🎜🎜renderSlot akzeptiert fünf Parameter. Der erste ist das Slot-Funktionsobjekt slots für die Instanz und der zweite ist der Name des Slots, der den Slot-Inhalt rendern soll Die angegebene Position, der dritte sind die vom Slot-Bereich empfangenen props, der vierte ist die Standard-Content-Rendering-Funktion des Slots und beim fünften ist nicht klar, was das bedeutet. 🎜🎜Prinzip des Scope-Slots🎜🎜Scope-Slot ist eine Möglichkeit für untergeordnete Komponenten, Parameter von übergeordneten Komponenten zu übergeben, sodass Slot-Inhalte nur auf Daten in untergeordneten Komponenten zugreifen können. 🎜🎜Unterkomponentenvorlage🎜
export function render(_ctx, _cache, $props, $setup, $data, $options) {
  return (_openBlock(), _createElementBlock("div", { class: "container" }, [
    _createElementVNode("header", null, [
      _renderSlot(_ctx.$slots, "header")
    ]),
    _createElementVNode("main", null, [
      _renderSlot(_ctx.$slots, "default")
    ]),
    _createElementVNode("footer", null, [
      _renderSlot(_ctx.$slots, "footer")
    ])
  ]))
}
Nach dem Login kopieren
Nach dem Login kopieren
🎜Kompilierter Code🎜
// renderSlots的简化
export function renderSlots(slots, name, props) {
  const slot = slots[name]
  if (slot) {
    if (typeof slot === &#39;function&#39;) {
      return createVNode(Fragment, {}, slot(props))
    }
  }
}
Nach dem Login kopieren
Nach dem Login kopieren
🎜Übergeordnete Komponentenvorlage🎜
{
    header: _withCtx(() => [
      _createElementVNode("h2", null, "header")
    ]),
    default: _withCtx(() => [
      _createElementVNode("p", null, "default")
    ]),
    footer: _withCtx(() => [
      _createElementVNode("p", null, "footer")
    ]),
    _: 1 /* STABLE */
}
Nach dem Login kopieren
Nach dem Login kopieren
🎜Kompilierter Code🎜
<button type="submit">
  <slot>Submit</slot>
</button>
Nach dem Login kopieren
Nach dem Login kopieren
🎜Die RenderSlot-Funktion wurde oben erwähnt, die einfach in den folgenden Code zusammengefasst werden kann🎜
<submit-button></submit-button>
Nach dem Login kopieren
🎜slots</ Code > ist der von der Komponenteninstanz hochgeladene Slot-Inhalt. Tatsächlich handelt es sich um diesen Inhalt. „coboy“ }), wodurch die Daten in der untergeordneten Komponente an den Slot-Inhalt der übergeordneten Komponente übergeben werden. 🎜<h3 id="具名插槽原理">具名插槽原理</h3><p>有时我们需要多个插槽。例如对于一个带有如下模板的 <code><base-layout> 组件:

<div class="container">
  <header>
    <!-- 我们希望把页头放这里 -->
  </header>
  <main>
    <!-- 我们希望把主要内容放这里 -->
  </main>
  <footer>
    <!-- 我们希望把页脚放这里 -->
  </footer>
</div>
Nach dem Login kopieren
Nach dem Login kopieren

对于这样的情况,<slot> 元素有一个特殊的 attribute:name。通过它可以为不同的插槽分配独立的 ID,也就能够以此来决定内容应该渲染到什么地方:

<!--子组件-->
<div class="container">
  <header>
    <slot name="header"></slot>
  </header>
  <main>
    <slot></slot>
  </main>
  <footer>
    <slot name="footer"></slot>
  </footer>
</div>
Nach dem Login kopieren
Nach dem Login kopieren

一个不带 name<slot> 出口会带有隐含的名字“default”。

在向具名插槽提供内容的时候,我们可以在一个 <template> 元素上使用 v-slot 指令,并以 v-slot 的参数的形式提供其名称:

<!--父组件-->
<base-layout>
  <template v-slot:header>
    <h2 id="header">header</h2>
  </template>
  <template v-slot:default>
    <p>default</p>
  </template>
  <template v-slot:footer>
    <p>footer</p>
  </template>
</base-layout>
Nach dem Login kopieren
Nach dem Login kopieren

父组件编译之后的内容:

export function render(_ctx, _cache, $props, $setup, $data, $options) {
  const _component_base_layout = _resolveComponent("base-layout")
  return (_openBlock(), _createBlock(_component_base_layout, null, {
    header: _withCtx(() => [
      _createElementVNode("h2", null, "header")
    ]),
    default: _withCtx(() => [
      _createElementVNode("p", null, "default")
    ]),
    footer: _withCtx(() => [
      _createElementVNode("p", null, "footer")
    ]),
    _: 1 /* STABLE */
  }))
}
Nach dem Login kopieren
Nach dem Login kopieren

子组件编译之后的内容:

export function render(_ctx, _cache, $props, $setup, $data, $options) {
  return (_openBlock(), _createElementBlock("div", { class: "container" }, [
    _createElementVNode("header", null, [
      _renderSlot(_ctx.$slots, "header")
    ]),
    _createElementVNode("main", null, [
      _renderSlot(_ctx.$slots, "default")
    ]),
    _createElementVNode("footer", null, [
      _renderSlot(_ctx.$slots, "footer")
    ])
  ]))
}
Nach dem Login kopieren
Nach dem Login kopieren

通过子组件编译之后的内容我们可以看到这三个Slot渲染函数

_renderSlot(_ctx.$slots, "header")

_renderSlot(_ctx.$slots, "default")

_renderSlot(_ctx.$slots, "footer")

然后我们再回顾一下renderSlot渲染函数

// renderSlots的简化
export function renderSlots(slots, name, props) {
  const slot = slots[name]
  if (slot) {
    if (typeof slot === &#39;function&#39;) {
      return createVNode(Fragment, {}, slot(props))
    }
  }
}
Nach dem Login kopieren
Nach dem Login kopieren

这个时候我们就可以很清楚的知道所谓具名函数是通过renderSlots渲染函数的第二参数去定位要渲染的父组件提供的插槽内容。父组件的插槽内容编译之后变成了一个Object的数据类型。

{
    header: _withCtx(() => [
      _createElementVNode("h2", null, "header")
    ]),
    default: _withCtx(() => [
      _createElementVNode("p", null, "default")
    ]),
    footer: _withCtx(() => [
      _createElementVNode("p", null, "footer")
    ]),
    _: 1 /* STABLE */
}
Nach dem Login kopieren
Nach dem Login kopieren

默认内容插槽的原理

我们可能希望这个 <button> 内绝大多数情况下都渲染“Submit”文本。为了将“Submit”作为备用内容,我们可以将它放在 <slot> 标签内

<button type="submit">
  <slot>Submit</slot>
</button>
Nach dem Login kopieren
Nach dem Login kopieren

现在当我们在一个父级组件中使用 <submit-button> 并且不提供任何插槽内容时:

<submit-button></submit-button>
Nach dem Login kopieren

备用内容“Submit”将会被渲染:

<button type="submit">
  Submit
</button>
Nach dem Login kopieren

但是如果我们提供内容:

<submit-button>
  Save
</submit-button>
Nach dem Login kopieren

则这个提供的内容将会被渲染从而取代备用内容:

<button type="submit">
  Save
</button>
Nach dem Login kopieren

这其中的原理是什么呢?我们先来看看上面默认内容插槽编译之后的代码

export function render(_ctx, _cache, $props, $setup, $data, $options) {
  return (_openBlock(), _createElementBlock("button", { type: "submit" }, [
    _renderSlot(_ctx.$slots, "default", {}, () => [
      _createTextVNode("Submit")
    ])
  ]))
}
Nach dem Login kopieren

我们可以看到插槽函数的内容是这样的

_renderSlot(_ctx.$slots, "default", {}, () => [
    _createTextVNode("Submit")
])
Nach dem Login kopieren

我们再回顾看一下renderSlot函数

renderSlot函数接受五个参数,第四个是插槽的默认内容渲染函数。

Was ist das Implementierungsprinzip des Vue3-Slot-Slots?

再通过renderSlot函数的源码我们可以看到,

第一步,先获取父组件提供的内容插槽的内容,

在第二个步骤中,若父组件已提供插槽内容,则使用该插槽内容,否则执行默认的内容渲染函数以获取默认内容。

Das obige ist der detaillierte Inhalt vonWas ist das Implementierungsprinzip des Vue3-Slot-Slots?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

vue3+vite: So beheben Sie den Fehler bei der Verwendung von require zum dynamischen Importieren von Bildern in src vue3+vite: So beheben Sie den Fehler bei der Verwendung von require zum dynamischen Importieren von Bildern in src May 21, 2023 pm 03:16 PM

vue3+vite:src verwendet „require“, um Bilder dynamisch zu importieren, und vue3+vite importiert dynamisch mehrere Bilder. Wenn Sie „requireisnotdefined“ verwenden, wird eine Fehlermeldung angezeigt like vue2 like imgUrl:require(' .../assets/test.png') wird importiert, da Typescript Require nicht unterstützt, daher wird Import verwendet. So lösen Sie das Problem: Verwenden Sieawaitimport

So verwenden Sie tinymce im Vue3-Projekt So verwenden Sie tinymce im Vue3-Projekt May 19, 2023 pm 08:40 PM

tinymce ist ein voll funktionsfähiges Rich-Text-Editor-Plug-in, aber die Einführung von tinymce in Vue ist nicht so reibungslos wie bei anderen Vue-Rich-Text-Plug-ins. Tinymce selbst ist nicht für Vue geeignet, und @tinymce/tinymce-vue muss eingeführt werden. und Es handelt sich um ein ausländisches Rich-Text-Plug-in, das die chinesische Version nicht bestanden hat. Sie müssen das Übersetzungspaket von der offiziellen Website herunterladen (möglicherweise müssen Sie die Firewall umgehen). 1. Installieren Sie die zugehörigen Abhängigkeiten npminstalltinymce-Snpminstall@tinymce/tinymce-vue-S2. 3. Führen Sie den Skin und das chinesische Paket ein. Erstellen Sie einen neuen Tinymce-Ordner im öffentlichen Ordner des Projekts und laden Sie ihn herunter

Wie Vue3 Markdown analysiert und Code-Hervorhebung implementiert Wie Vue3 Markdown analysiert und Code-Hervorhebung implementiert May 20, 2023 pm 04:16 PM

Um das Blog-Frontend mit Vue zu implementieren, müssen Sie die Markdown-Analyse implementieren. Wenn Code vorhanden ist, müssen Sie die Code-Hervorhebung implementieren. Es gibt viele Markdown-Parsing-Bibliotheken für Vue, wie z. B. markdown-it, vue-markdown-loader, markiert, vue-markdown usw. Diese Bibliotheken sind alle sehr ähnlich. Hier wird Markiert verwendet, und highlights.js wird als Code-Hervorhebungsbibliothek verwendet. Die spezifischen Implementierungsschritte lauten wie folgt: 1. Installieren Sie abhängige Bibliotheken. Öffnen Sie das Befehlsfenster unter dem Vue-Projekt und geben Sie den folgenden Befehl ein: npminstallmarked-save//marked, um Markdown in htmlnpmins zu konvertieren

So aktualisieren Sie einen Teilinhalt der Seite in Vue3 So aktualisieren Sie einen Teilinhalt der Seite in Vue3 May 26, 2023 pm 05:31 PM

Um eine teilweise Aktualisierung der Seite zu erreichen, müssen wir nur das erneute Rendern der lokalen Komponente (dom) implementieren. In Vue lässt sich dieser Effekt am einfachsten mit der v-if-Direktive erzielen. In Vue2 können wir zusätzlich zur Verwendung der v-if-Anweisung zum erneuten Rendern des lokalen Doms auch eine neue leere Komponente erstellen. Wenn wir die lokale Seite aktualisieren müssen, springen wir zu dieser leeren Komponentenseite und springen dann wieder hinein der beforeRouteEnter-Schutz in der leeren Komponente. Wie in der Abbildung unten gezeigt, wie man in Vue3.X auf die Schaltfläche „Aktualisieren“ klickt, um das DOM im roten Feld neu zu laden und den entsprechenden Ladestatus anzuzeigen. Da der Guard in der Komponente in der scriptsetup-Syntax in Vue3.X nur o hat

So verwenden Sie wiederverwendbare Vue3-Komponenten So verwenden Sie wiederverwendbare Vue3-Komponenten May 20, 2023 pm 07:25 PM

Vorwort Ob Vue oder React: Wenn wir auf mehrere wiederholte Codes stoßen, werden wir darüber nachdenken, wie wir diese Codes wiederverwenden können, anstatt eine Datei mit einer Reihe redundanter Codes zu füllen. Tatsächlich können sowohl Vue als auch React eine Wiederverwendung durch Extrahieren von Komponenten erreichen. Wenn Sie jedoch auf einige kleine Codefragmente stoßen und keine andere Datei extrahieren möchten, kann React im Vergleich dazu verwendet werden Deklarieren Sie das entsprechende Widget in der Datei , oder implementieren Sie es über die Renderfunktion, wie zum Beispiel: constDemo:FC=({msg})=>{returndemomsgis{msg}}constApp:FC=()=>{return(

So wählen Sie einen Avatar aus und schneiden ihn in Vue3 zu So wählen Sie einen Avatar aus und schneiden ihn in Vue3 zu May 29, 2023 am 10:22 AM

Der letzte Effekt besteht darin, die VueCropper-Komponente „garnaddvue-cropper@next“ zu installieren. Wenn es sich um Vue3 handelt oder Sie andere Methoden als Referenz verwenden möchten, besuchen Sie bitte die offizielle npm-Adresse. Es ist auch sehr einfach, es in einer Komponente zu referenzieren und zu verwenden. Sie müssen nur die entsprechende Komponente und ihre Stildatei einführen. Ich verweise hier nicht global, sondern nur auf import{userInfoByRequest}from'../js/api ' in meiner Komponentendatei. import{VueCropper}from'vue-cropper&

So verwenden Sie defineCustomElement zum Definieren von Komponenten in Vue3 So verwenden Sie defineCustomElement zum Definieren von Komponenten in Vue3 May 28, 2023 am 11:29 AM

Verwenden von Vue zum Erstellen benutzerdefinierter Elemente. WebComponents ist ein Sammelname für eine Reihe webnativer APIs, die es Entwicklern ermöglichen, wiederverwendbare benutzerdefinierte Elemente (Customelements) zu erstellen. Der Hauptvorteil von benutzerdefinierten Elementen besteht darin, dass sie mit jedem Framework verwendet werden können, auch ohne Framework. Sie sind ideal, wenn Sie Endbenutzer ansprechen, die möglicherweise einen anderen Front-End-Technologie-Stack verwenden, oder wenn Sie die endgültige Anwendung von den Implementierungsdetails der verwendeten Komponenten entkoppeln möchten. Vue und WebComponents sind komplementäre Technologien und Vue bietet hervorragende Unterstützung für die Verwendung und Erstellung benutzerdefinierter Elemente. Sie können benutzerdefinierte Elemente in bestehende Vue-Anwendungen integrieren oder Vue zum Erstellen verwenden

So verwenden Sie vue3+ts+axios+pinia, um eine sinnlose Aktualisierung zu erreichen So verwenden Sie vue3+ts+axios+pinia, um eine sinnlose Aktualisierung zu erreichen May 25, 2023 pm 03:37 PM

vue3+ts+axios+pinia realisiert sinnlose Aktualisierung 1. Laden Sie zuerst aiXos und pinianpmipinia im Projekt herunter--savenpminstallaxios--save2. AxiosResponse}from"axios";importaxiosfrom'axios';import{ElMess

See all articles