Vorwort: Wenn wir Vue verwenden, verwenden und schreiben wir häufig einige benutzerdefinierte Plug-Ins und führen sie dann mit Nach dem Lesen dieses Artikels erfahren Sie:
Okay, ohne weitere Umschweife, fangen wir an! ! ! 1. Durchführung der Installation in Vuex&Vue-RouterHier sind zwei Fragen, über die Sie nachdenken sollten. Sie sind wie das Graben von Löchern. Ich werde sie unten einzeln beantworten:
Tatsächlich sind die Prinzipien beider gleich. Hier verwenden wir Klasse Router { Konstruktor(Optionen) { ... } } Router.install = Funktion(_Vue) { _Vue.mixin({ vorErstellen() { wenn (diese.$options.router) { _Vue.prototype.$router = diese.$options.router } } }) } Standardrouter exportieren;
Lassen Sie uns in diesem Fall ein mutiges Urteil fällen. Keine Sorge, wir haben gerade das erste Problem gelöst, jetzt füllen wir das zweite Loch. Normalerweise verwenden wir // router/index.js importiere VueRouter von „vue-router“; importiere Vue von „vue“; Vue.use(VueRouter); const _router = [ ... ] const Router = neuer VueRouter(_router); Standardrouter exportieren; // Haupt.js importiere Vue von „vue“; Router von „Router“ importieren; neuer Vue({ Router, ... }).$mount('#app'); Lassen Sie uns zunächst das ursprüngliche Beispiel analysieren.
beißen! ! ! Es wurden Elemente erkannt, also lasst uns eine kühne Vermutung anstellen. 2. Interne Implementierung der Installation in Vue Nachdem Sie die Verwendung der häufig verwendeten Bibliothek Exportfunktion initUse (Vue: GlobalAPI) { //Registriere eine auf der Instanz gemountete Use-Methode Vue.use = function (plugin: Function | Object) { // Array der aktuellen Plugins initialisieren const installedPlugins = (this._installedPlugins || (this._installedPlugins = [])) // Wenn dieses Plugin bereits registriert wurde, dann verarbeite es nicht if (installedPlugins.indexOf(plugin) > -1) { gib das zurück } ... // Jetzt kommt der Punkt! ! ! wenn (Typ des Plugins.install === 'Funktion') { // Wenn „install“ eine Funktion im Plugin ist, rufen Sie die Installationsmethode auf, zeigen Sie auf das Plugin und übergeben Sie eine Reihe von Parametern an plugin.install.apply(plugin, args). } sonst wenn (Typ des Plugins === 'Funktion') { // Wenn das Plugin selbst eine Funktion ist, behandeln Sie es als Installationsmethode, zeigen Sie auf das Plugin und übergeben Sie eine Reihe von Parametern an plugin.apply(null, args). } //Setze das Plugin in das Plugin-Array ein installedPlugins.push(plugin) gib das zurück } } Dieser Teil des Quellcodes ist sehr prägnant und gut lesbar. Das heißt, bei der Verwendung den Plugin-Typ bestimmen und Abschluss: Ich frage mich, ob Sie den Plug-In-Mechanismus von Vue besser verstehen? Tatsächlich können wir bei der Entwicklung von Plug-Ins Dies ist das Ende dieses Artikels über ein vertieftes Verständnis des Plug-In-Mechanismus und Das könnte Sie auch interessieren:
|
<<: Bei der Verwendung von mybatis-generator mit mysql8.0.3 in IDEA sind Fehler aufgetreten
>>: Ausführliche Erläuterung der gespeicherten MySQL-Prozeduren (in, out, inout)
Beim Anpassen der Softwareinstallation müssen Sie...
Vorwort Das Konzept des Dunkelmodus stammt ursprü...
Vorwort: Wie erhält man die Koordinaten der aktue...
In diesem Artikel wird der spezifische Code von j...
Vorwort Wer schon einmal mit MySQL gespielt hat, ...
1. Einleitung Kürzlich habe ich festgestellt, das...
Hier sind einige Möglichkeiten zum Entfernen: Füge...
Inhaltsverzeichnis Docker-Installation Nvidia-Doc...
Inhaltsverzeichnis Vorwort 1. Lokale Portweiterle...
Es gibt drei Typen von MySQL-gespeicherten Prozed...
Drei Möglichkeiten, CSS in HTML zu verwenden: 1. ...
Starten Sie die virtuelle Centos8-Maschine und dr...
(Wenn eine Webseite geladen wird, gibt es manchma...
Nachfragehintergrund: Fügen Sie dynamische GIF-Bi...
Konventionelle Lösung Verwenden Sie FileReader, u...