Heim >Web-Frontend >View.js >Wie optimiert man die Leistung in Vue.js? 9 Tipps zum Teilen
Wie optimiert man die Leistung in Vue.js? Der folgende Artikel wird Ihnen neun Tipps zur Leistungsoptimierung von Vue.js geben. Ich hoffe, er wird für alle hilfreich sein!
(Lernvideofreigabe: VueJS Tutorial)
Anwendbare Szenarien:
**Prinzip: **Wenn Sie den Vorher- und Nachher-Code vergleichen, können Sie feststellen, dass der Unterschied darin besteht: Der Code vor der Optimierung verweist bei jeder Berechnung direkt auf this.base, während der Code nach der Optimierung verwendet wird Lokale Variablenbasis zur Berechnung von this.base Nach dem Zwischenspeichern werden lokale Variablen zur Berechnung in nachfolgenden Berechnungen aufgerufen. Warum gibt es einen so offensichtlichen Leistungsunterschied? Der Grund dafür ist, dass bei jedem Zugriff auf this.base ein Teil des Logikcodes ausgeführt wird, um festzustellen, ob sich die vorhandenen Abhängigkeiten geändert haben. Andernfalls werden sie neu berechnet , wird der zuletzt berechnete Wert zurückgegeben. Der Leistungsverbrauch dieser Art von Berechnungslogik ist möglicherweise nicht offensichtlich, wenn sie nur wenige Male aufgerufen wird, aber wenn sie zu oft ausgeführt wird (ähnlich dem Beispiel, in dem 300 Komponenten pro Frame aktualisiert werden und jede Komponente this.base mehrfach aufruft). Mal innerhalb eines Updates), dann wird es einen relativ großen Leistungsunterschied geben. 04 DOM mit V-Show wiederverwenden durch Festlegen des Anzeigestilattributs des DOM-Elements.
Kompilierungsbedingungen: v-if ist faul, wenn die Anfangsbedingung falsch ist, tun Sie nichts, starten Sie die teilweise Kompilierung nur, wenn die Bedingung zum ersten Mal wahr wird, v-show wird unter allen Bedingungen kompiliert und dann zwischengespeichert. und die DOM-Elemente bleiben erhalten.
Leistungsverbrauch: v-if hat höhere Wechselkosten, v-show hat höhere anfängliche Renderingkosten.Verwendungsszenarien: v-if eignet sich für Situationen, in denen sich die Bedingungen wahrscheinlich nicht ändern, v-show eignet sich für Situationen, in denen sich die Bedingungen häufig ändern.
**Prinzip: **In nicht optimierten Szenarien wird die Komponente jedes Mal neu erstellt, wenn wir auf die Schaltfläche zum Wechseln der Routing-Ansicht klicken -gerendert, und die Rendering-Komponente durchläuft die Komponenteninitialisierung, das Rendern, das Patchen und andere Prozesse. Wenn die Komponente komplex oder tief verschachtelt ist, dauert das gesamte Rendering lange. Nach der Verwendung von KeepAlive werden der Vnode und das DOM der von KeepAlive verpackten Komponente nach dem ersten Rendern zwischengespeichert. Beim nächsten Rendern der Komponente werden der entsprechende Vnode und das DOM dann direkt aus dem Cache abgerufen. Es ist nicht erforderlich, eine Reihe von Prozessen wie Komponenteninitialisierung, Rendern und Patchen usw. durchzuführen, was die Ausführungszeit des Skripts verkürzt und eine bessere Leistung bietet.
Aber die Verwendung der KeepAlive-Komponente ist nicht kostenlos, da sie mehr Speicher für das Caching beansprucht. Dies ist eine typische Anwendung von Ideen zur Raum-Zeit-Optimierung. 06 Deferred-Funktionen in mehrere Male Die displayPriority-Variable wird intern verwaltet und während jedes Rendering-Frames durch requestAnimationFrame bis zur Anzahl erhöht. Dann können Sie innerhalb der Komponente, die das Defer-Mixin verwendet, v-if="defer(xxx)" verwenden, um das Rendering bestimmter Blöcke zu steuern, wenn die displayPriority auf xxx erhöht wird.
08 Nicht reaktive Daten
**Prinzip: **Bei der internen Übermittlung von Daten werden die neu übermittelten Daten standardmäßig als reaktiv definiert, wenn die Untereigenschaft des Objekt ist ein Objekt. Es wird auch Untereigenschaften rekursiv reagieren lassen. Wenn daher zu viele Daten übermittelt werden, ist der gesamte Prozess sehr zeitaufwändig. Nach der Optimierung wird das in den Daten konfigurierbare Attributflag manuell in „false“ geändert, sodass das intern über Object.keys (obj) erhaltene Objektattributarray Daten ignoriert und das Datenattribut nicht definiert wirdReaktiv, da Daten auf ein Objekt verweisen. Dadurch wird auch die rekursive Antwortlogik reduziert, was einer Verringerung des Leistungsverlusts dieses Teils entspricht. Je größer die Datenmenge, desto deutlicher wird der Effekt dieser Optimierung sein.Der Unterschied zwischen der Einstellung konfigurierbar und der direkten Verwendung von Object.freeze besteht darin:
wird verwendet, um die Änderung und Löschung von Attributflags zu verhindern, ermöglicht jedoch die Änderung des Werts des Objekts**Object.freeze(obj)**
禁止添加/删除/更改属性。为所有现有的属性设置 configurable: false
, writable: false
.
// configurable: false let user = { name: "John" }; Object.defineProperty(user, "name", { configurable: false }); user.name = "Pete"; // 正常工作 delete user.name; // Error // Object.freeze(obj) let user = { name: "John" }; Object.freeze(user); user.name = "Pete"; console.log(user.name); // "John"复制代码
**Prinzip: **Virtuelles Scrollen wird implementiert, indem nur das DOM innerhalb des Ansichtsbereichs gerendert wird. Die Leistung ist natürlich viel besser, wenn weniger Inhalte gerendert werden. Die virtuelle Scroll-Komponente wurde ebenfalls von Guillaume Chau geschrieben. Interessierte Schüler können ihre Quellcode-Implementierung studieren. Das Grundprinzip besteht darin, Scroll-Ereignisse zu überwachen, die anzuzeigenden DOM-Elemente dynamisch zu aktualisieren und deren Verschiebung zu berechnen Sicht. Die virtuelle Bildlaufkomponente ist nicht kostenlos, da sie während des Bildlaufvorgangs in Echtzeit berechnet werden muss, sodass bestimmte Kosten für die Skriptausführung anfallen. Wenn die Datenmenge in der Liste daher nicht sehr groß ist, reicht es für uns aus, normales Scrollen zu verwenden
Dieser Artikel wurde reproduziert von: https://juejin.cn/post/7084809333740929061
(Lernvideo Teilen: Web-Frontend-Entwicklung )
Das obige ist der detaillierte Inhalt vonWie optimiert man die Leistung in Vue.js? 9 Tipps zum Teilen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!