suchen
HeimWeb-FrontendView.jsLassen Sie uns darüber sprechen, wie Sie Vue3 zum Erstellen von Webkomponenten verwenden

Wie erstellt man Webkomponenten mit Vue3? Der folgende Artikel stellt Ihnen die Methode zum Erstellen von Webkomponenten mit Vue3 vor. Ich hoffe, er wird Ihnen hilfreich sein!

Lassen Sie uns darüber sprechen, wie Sie Vue3 zum Erstellen von Webkomponenten verwenden

Manchmal möchte ich eine Framework-unabhängige Komponente schreiben, aber ich möchte zum Schreiben weder Native noch Jquery verwenden, und ich möchte auch Stilkonflikte vermeiden. Es fühlt sich einfach richtig an, dies zu tun Es. Aber jetzt sind Webkomponenten immer noch nicht flexibel genug und an vielen Stellen immer noch unpraktisch. Es wäre großartig, wenn sie in Verbindung mit MVVM verwendet werden könnten. Angular hat das Erstellen von Komponenten in Webkomponenten schon lange unterstützt. Vue3 3.2+ unterstützt endlich das Erstellen von Komponenten in Webkomponenten. Ich wollte das Kommentar-Plugin kürzlich neu erstellen und habe es daher ausprobiert.

Erstellen von Webkomponenten

vue bietet eine defineCustomElement-Methode, um die Vue-Komponente in einen auf HTMLElement erweiterten benutzerdefinierten Funktionskonstruktor umzuwandeln. Die Verwendung ist im Wesentlichen die gleiche wie die defineComponent-Parameter-API. [Verwandte Empfehlungen: vuejs-Video-Tutorial]

import { defineCustomElement } from 'vue' 

const MyVueElement = defineCustomElement({
  // 在此提供正常的 Vue 组件选项
  props: {},
  emits: {},
  template: `...`,

  // defineCustomElement 独有特性: CSS 会被注入到隐式根 (shadow root) 中
  styles: [`/* inlined css */`]
})

// 注册 Web Components
customElements.define('my-vue-element', MyVueElement)

Wenn Sie eine einzelne Datei verwenden müssen, benötigen Sie @vitejs/plugin-vue@^1.4.0 oder vue-loader@^16.5.0 oder a höhere Version des Tools. Wenn nur einige Dateien verwendet werden müssen, können Sie das Suffix in .ce.vue ändern. Wenn Sie alle Dateien Web Components erstellen müssen, können Sie das Konfigurationselement customElement von @vitejs/plugin-vue@^1.4.0 oder vue-loader@^16.5.0 aktivieren. Auf diese Weise müssen Sie das Suffix .ce.vue nicht mehr verwenden.

Attribute

vue ordnet alle Requisiten den Eigenschaften des benutzerdefinierten Elementobjekts zu und ordnet auch die Attribute den benutzerdefinierten Element-Tags zu.

<com-demo></com-demo>

props:{
  type:String
}

Da HTML-Attribute nur Zeichenfolgen sein können, hilft Vue bei der Typkonvertierung während der Zuordnung.

Events

In benutzerdefinierten Elementen werden Ereignisse, die über

this.$emit

oder emit in setup ausgegeben werden, als native CustomEvents versendet. Zusätzliche Ereignisparameter (Nutzlast) werden als Array in der Details-Eigenschaft des CustomEvent-Objekts verfügbar gemacht.

Slots

Beim Schreiben von Komponenten können Sie es wie Vue verwenden, aber Sie können nur die native Slot-Syntax verwenden, sodass Scope-Slots nicht mehr unterstützt werden.

Problem mit Unterkomponentenstilen

Bei der Verwendung verschachtelter Unterkomponenten besteht die Gefahr, dass die Stile in den Unterkomponenten nicht standardmäßig extrahiert werden.

Übergeordnete Komponente

<template>
    <div>{{ title }}</div>
    <childer></childer>
</template>
<script>
import Childer from "./childer.vue"
export default {
    components: { Childer },
    data() {
        return {
            title: "父组件"
        }
    },
}
</script>
<style>
.title {
    padding: 10px;
    background-color: #eee;
    font-weight: bold;
}
</style>

Untergeordnete Komponente

<template>
    <div>{{ title }}</div>
</template>
<script>
export default {
    data() {
        return {
            title: "子组件"
        }
    },
}
</script>
<style>
.childer {
    padding: 10px;
    background-color: #222;
    color: #fff;
    font-weight: bold;
}
</style>

Sie können sehen, dass der Stil der untergeordneten Komponente nicht eingefügt wird, aber die Stilisolationskennung generiert wird data-v-5e87e937. Ich weiß nicht, ob der Vue-Beamte diesen Fehler in Zukunft beheben wird.

Wenn Sie sich die Komponenten ansehen, können Sie sehen, dass die Stile der Unterkomponenten extrahiert wurden, sodass Sie sie nur selbst einfügen müssen. Lassen Sie uns darüber sprechen, wie Sie Vue3 zum Erstellen von Webkomponenten verwenden

Lassen Sie uns darüber sprechen, wie Sie Vue3 zum Erstellen von Webkomponenten verwendenExtrahieren Sie den Stil der Unterkomponente und fügen Sie ihn in die übergeordnete Komponente ein. Weitere Informationen finden Sie in dieser Implementierung wird nicht standardmäßig erstellt. Um die Methode an

customElement

anzuhängen, schauen Sie sich den Vue-Quellcode an, dort gibt es nur _def (Konstruktor), _instance (Komponenteninstanz)). Wenn Sie eine Methode innerhalb der Komponente dom._instance.proxy.fun() aufrufen möchten, fühlt sich das wirklich unelegant an.

Natürlich hoffen wir, dass die von unseren Komponenten bereitgestellten Methoden direkt wie gewöhnliches Dom verwendet werden können, ohne dom.fun() zu verwenden. Wir haben

defineCustomElementLassen Sie uns darüber sprechen, wie Sie Vue3 zum Erstellen von Webkomponenten verwenden leicht erweitert.

import ComDemo from '~/demo/index.vue'

const deepStylesOf = ({ styles = [], components = {} }) => {
    const unique = array => [...new Set(array)];
    return unique([...styles, ...Object.values(components).flatMap(deepStylesOf)]);
}
// 将子组件样式插入到父组件里
ComDemo.styles = deepStylesOf(ComDemo)

!customElements.get('com-demo') && customElements.define('com-demo', defineCustomElement(ComDemo))

Zusammenfassung

Im Allgemeinen gibt es immer noch viele Fallstricke. Wenn Sie nur einige relativ einfache Framework-übergreifende Plug-Ins erstellen müssen, ist die Verwendung dieser Methode zum Erstellen von Webkomponenten ebenfalls eine gute Lösung. Weitere Kenntnisse zum Thema Programmierung finden Sie unter: Einführung in die Programmierung! !

Das obige ist der detaillierte Inhalt vonLassen Sie uns darüber sprechen, wie Sie Vue3 zum Erstellen von Webkomponenten verwenden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Dieser Artikel ist reproduziert unter:博客园. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen
Netflix -Frontend: Beispiele und Anwendungen von React (oder Vue)Netflix -Frontend: Beispiele und Anwendungen von React (oder Vue)Apr 16, 2025 am 12:08 AM

Netflix verwendet React als Front-End-Framework. 1) Reacts komponentiertes Entwicklungsmodell und ein starkes Ökosystem sind die Hauptgründe, warum Netflix es ausgewählt hat. 2) Durch die Komponentierung spaltet Netflix komplexe Schnittstellen in überschaubare Teile wie Videotiere, Empfehlungslisten und Benutzerkommentare auf. 3) Die virtuelle DOM- und Komponentenlebenszyklus von React optimiert die Rendering -Effizienz und die Verwaltung des Benutzerinteraktion.

Die Frontend -Landschaft: Wie Netflix ihre Auswahl annähteDie Frontend -Landschaft: Wie Netflix ihre Auswahl annähteApr 15, 2025 am 12:13 AM

Die Auswahl von Netflix in der Front-End-Technologie konzentriert sich hauptsächlich auf drei Aspekte: Leistungsoptimierung, Skalierbarkeit und Benutzererfahrung. 1. Leistungsoptimierung: Netflix wählte React als Hauptgerüst und entwickelte Tools wie SpeedCurve und Boomerang, um die Benutzererfahrung zu überwachen und zu optimieren. 2. Skalierbarkeit: Sie übernehmen eine Mikro-Front-End-Architektur, die Anwendungen in unabhängige Module aufteilt und die Entwicklungseffizienz und die Systemskalierbarkeit verbessern. 3. Benutzererfahrung: Netflix verwendet die Material-UI-Komponentenbibliothek, um die Schnittstelle kontinuierlich durch A/B-Tests und Benutzer-Feedback zu optimieren, um Konsistenz und Ästhetik sicherzustellen.

React vs. Vue: Welches Framework verwendet Netflix?React vs. Vue: Welches Framework verwendet Netflix?Apr 14, 2025 am 12:19 AM

NetflixuSesacustomframeworkcalted "Gibbon" Builtonreact, NotreactorVuedirect.1) TeamExperience: Wählen Sie beobädtes Vertrauen

Die Wahl der Frameworks: Was treibt die Entscheidungen von Netflix vor?Die Wahl der Frameworks: Was treibt die Entscheidungen von Netflix vor?Apr 13, 2025 am 12:05 AM

Netflix berücksichtigt hauptsächlich Leistung, Skalierbarkeit, Entwicklungseffizienz, Ökosystem, technische Schulden und Wartungskosten bei der Rahmenauswahl. 1. Leistung und Skalierbarkeit: Java und Springboot werden ausgewählt, um massive Daten und hohe gleichzeitige Anforderungen effizient zu verarbeiten. 2. Entwicklungseffizienz und Ökosystem: Verwenden Sie React, um die Effizienz der Front-End-Entwicklung zu verbessern und sein reiches Ökosystem zu nutzen. 3. Technische Schulden- und Wartungskosten: Wählen Sie Node.js, um Microservices zu erstellen, um Wartungskosten und technische Schulden zu senken.

Reagieren, Vue und die Zukunft von Netflix 'FrontendReagieren, Vue und die Zukunft von Netflix 'FrontendApr 12, 2025 am 12:12 AM

Netflix verwendet React hauptsächlich als Front-End-Framework, das durch VUE für bestimmte Funktionen ergänzt wird. 1) Die Komponentierung von React und das virtuelle DOM verbessern die Leistung und Entwicklungseffizienz von Netflix -Anwendungen. 2) VUE wird in den internen Tools und kleinen Projekten von Netflix verwendet, und seine Flexibilität und Benutzerfreundlichkeit sind entscheidend.

Vue.js im Frontend: Anwendungen und Beispiele in realer WeltVue.js im Frontend: Anwendungen und Beispiele in realer WeltApr 11, 2025 am 12:12 AM

Vue.js ist ein progressives JavaScript -Framework, das zum Erstellen komplexer Benutzeroberflächen geeignet ist. 1) Zu seinen Kernkonzepten gehören Reaktionsdaten, Komponentierungen und virtuelle DOM. 2) In praktischen Anwendungen kann es durch den Aufbau von Todo -Anwendungen und die Integration von Vuerouter demonstriert werden. 3) Beim Debuggen wird empfohlen, VODEVTOOLS und CONSOLE.LOG zu verwenden. 4) Die Leistungsoptimierung kann durch V-IF/V-Show, Listen-Rendering-Optimierung, asynchrone Belastung von Komponenten usw. erreicht werden.

Vue.js und React: Verständnis der wichtigsten UnterschiedeVue.js und React: Verständnis der wichtigsten UnterschiedeApr 10, 2025 am 09:26 AM

Vue.js ist für kleine bis mittelgroße Projekte geeignet, während React eher für große und komplexe Anwendungen geeignet ist. 1. Vue.js 'Responsive System aktualisiert das DOM automatisch durch Abhängigkeitsverfolgung und erleichtert es, Datenänderungen zu verwalten. 2.React übernimmt einen Einweg-Datenfluss, und die Datenflüsse von der übergeordneten Komponente zur untergeordneten Komponente und liefern einen klaren Datenfluss und eine leicht zu debug-Struktur.

Vue.js vs. React: projektspezifische ÜberlegungenVue.js vs. React: projektspezifische ÜberlegungenApr 09, 2025 am 12:01 AM

Vue.js eignet sich für kleine und mittelgroße Projekte und schnelle Iterationen, während React für große und komplexe Anwendungen geeignet ist. 1) Vue.js ist einfach zu bedienen und für Situationen geeignet, in denen das Team nicht ausreicht oder die Projektskala klein ist. 2) React hat ein reichhaltigeres Ökosystem und eignet sich für Projekte mit hoher Leistung und komplexen funktionalen Bedürfnissen.

See all articles

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)
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

EditPlus chinesische Crack-Version

EditPlus chinesische Crack-Version

Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

Dreamweaver Mac

Dreamweaver Mac

Visuelle Webentwicklungstools

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

SAP NetWeaver Server-Adapter für Eclipse

SAP NetWeaver Server-Adapter für Eclipse

Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.