Heim  >  Artikel  >  Web-Frontend  >  So implementieren Sie die automatische Registrierungsfunktion globaler vue3-Komponenten

So implementieren Sie die automatische Registrierungsfunktion globaler vue3-Komponenten

WBOY
WBOYnach vorne
2023-05-13 08:13:052943Durchsuche

Globale Komponenten von Vue3 werden automatisch registriert /components Die js-Datei wird zum Speichern und Registrieren importierter Komponenten verwendet (ich habe sie hier Index.js genannt)

Schritt 2: Schreiben Sie die Funktion

Erstellen Sie einen Ordner in coms und legen Sie die Komponente in diesem Ordner ab. Der Name ist der Name der Komponente, die wir registrieren werden.

So implementieren Sie die automatische Registrierungsfunktion globaler vue3-Komponenten

Schreiben Sie die folgende Toolfunktion in Index.js:

// 全局组件注册 需要到coms这个目录下注册
 
export default {
    install(app) {
        const req = require.context('./coms', true, /\.vue$/);
        req.keys().forEach((item) => {
            const defaultObj = req(item).default;
 
            let name = item.split('/')[1];
            // console.log('name', name);
            app.component(name, defaultObj);
        });
    }
};

Hinweis: Ich habe defaultObj.__file nicht verwendet, um den Dateipfad hier abzurufen, da das __file-Attribut in der Produktionsumgebung gelöscht wird, was Folgendes verursacht Fehler

So implementieren Sie die automatische Registrierungsfunktion globaler vue3-Komponenten

Schritt 3: Importieren Sie die Datei

Importieren Sie die Tool-Funktion in main.js und mounten Sie sie in die App

import coms from '@/components/Index'; //全局组件注册
app.use(coms);
So implementieren Sie die automatische Registrierungsfunktion globaler vue3-KomponentenSchritt 4: Global verwenden

In diesem Schritt können Sie den Dateinamen verwenden, den wir verwenden global als Komponentenname definiert.

ps: vue2 ist eigentlich ziemlich gleich, ändern Sie einfach app.use() in Vue.use()

Ergänzung: Vue3 registriert globale Komponenten

So implementieren Sie die automatische Registrierungsfunktion globaler vue3-KomponentenZum Beispiel werden Komponenten sehr häufig verwendet, fast auf jedem Seite Wenn sie alle verwendet werden, können sie in globale Komponenten gekapselt werden

Fügen Sie unsere Komponente in main.ts ein und folgen Sie createApp(App). ein Kettenaufruf Wenn Sie auf viele globale Komponenten stoßen, müssen Sie diese registrieren. Komponenten können Sie Middleware definieren, die Middleware die Komponentenregistrierung abschließen lassen und diese Middleware dann in main.js einführen und verwenden. Erstellen Sie eine neue index.ts Code in <code>src/components >Wird zum Importieren aller Komponenten verwendet, die eine globale Registrierung erfordern

vue3 globale automatische Komponentenregistrierung So implementieren Sie die Funktion

✨: Wenn Sie JS verwenden, können Sie die Typprüfung löschen

import { createApp } from &#39;vue&#39;
import App from &#39;./App.vue&#39;
import &#39;./assets/css/reset/index.less&#39;
import Card from &#39;./components/Card/index.vue&#39;
createApp(App).component(&#39;Card&#39;,Card).mount(&#39;#app&#39;) 
//.component(&#39;Card&#39;,Card)就是注册全局组件 (‘自定义键名&#39;,组件名)

2. Importieren Sie in main.ts

✨Hier verwenden: Registrieren Sie jede globale Komponente in einer Schleife

<template>
 <Card></Card>
</template>

3. Wenn Sie TS zum Schreiben verwenden, müssen Sie auch einen main erstellen. ts-Verzeichnis auf derselben Ebene. Code>components.d.ts, wird verwendet, um Komponenteneinführungsfehler zu behandeln und Komponententyp-Eingabeaufforderungen hinzuzufügen

Das obige ist der detaillierte Inhalt vonSo implementieren Sie die automatische Registrierungsfunktion globaler vue3-Komponenten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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