Heim  >  Artikel  >  Web-Frontend  >  Welche Vorteile haben Vuejs für die Entwicklung?

Welche Vorteile haben Vuejs für die Entwicklung?

藏色散人
藏色散人Original
2021-09-18 14:10:531900Durchsuche

Die Vorteile von Vuejs für die Entwicklung sind: 1. Kleinere Größe; 3. Es ermöglicht Entwicklern, keine DOM-Objekte mehr zu betreiben und 4. Reichhaltiges Ökosystem; Lernkosten.

Welche Vorteile haben Vuejs für die Entwicklung?

Die Betriebsumgebung dieses Artikels: Windows7-System, Vue2.5.17-Version, DELL G3-Computer.

Was sind die Vorteile von Vuejs für die Entwicklung?

Vue-Framework (Warum Vue verwenden, welche Vorteile bietet es)

1. Was ist Vue.js? Vue ist ein progressives JavaScript-Framework zum Erstellen von Benutzeroberflächen.

2. Vorteile von Vue.js

Geringe Größe: nur 33 KB nach der Komprimierung;

    Höhere Betriebseffizienz: Basierend auf dem virtuellen DOM kann man im Voraus verschiedene Berechnungen durchführen und das endgültige DOM berechnen und ausführen Optimierte Technologie: Da dieser DOM-Vorgang ein Vorverarbeitungsvorgang ist und das DOM nicht tatsächlich betreibt, wird er als virtuelles DOM bezeichnet.
  • Zwei-Wege-Datenbindung: Ermöglicht Entwicklern, keine DOM-Objekte mehr zu betreiben und mehr zu kombinieren
  • Reichhaltige Ökologie und niedrige Lernkosten: Es gibt eine große Anzahl ausgereifter und stabiler UI-Frameworks und -Komponenten auf Basis von vue.js, mit denen eine schnelle Entwicklung erreicht werden kann. Viele Lernmaterialien;
  • 3. Warum Vue.js verwenden? Mit der kontinuierlichen Weiterentwicklung der Front-End-Technologie kann die Front-End-Entwicklung immer mehr Unternehmen bewältigen und Webseiten werden immer leistungsfähiger dynamisch: Keiner dieser Fortschritte ist ohne JavaScript möglich. Bei der aktuellen Entwicklung wurde viel serverseitiger Code zur Ausführung in den Browser gelegt, der tausende Zeilen JavaScript-Code generiert, die mit verschiedenen HTML- und CSS-Dateien verbunden sind, allerdings fehlt es an einer formalen Organisationsform. Dies ist auch der Grund, warum immer mehr Frontend-Entwickler JavaScript-Frameworks verwenden. Zu den beliebtesten Frontend-Frameworks gehören derzeit Angular, Reac, Vue usw.

Vue ist ein benutzerfreundliches, vielseitiges und leistungsstarkes JavaScript-Framework, es kann Ihnen dabei helfen, eine besser wartbare und testbare Codebasis zu erstellen.

Vue ist ein progressives JavaScript-Framework

, was bedeutet, dass Sie Vue als Teil der Anwendung einbetten können, wenn Sie bereits über eine fertige Serveranwendung verfügen, um ein umfassenderes interaktives Erlebnis zu bieten. Oder wenn Sie mehr Geschäftslogik im Frontend implementieren möchten, können die Kernbibliothek und das Ökosystem von Vue auch Ihre verschiedenen Anforderungen erfüllen.

Wie andere Frameworks können Sie mit Vue eine Webseite in wiederverwendbare Komponenten unterteilen. Jede Komponente enthält ihr eigenes HTML, CSS und JavaScript, um die entsprechende Stelle auf der Webseite darzustellen. Wenn wir eine große Anwendung erstellen, müssen wir möglicherweise Dinge in separate Komponenten und Dateien aufteilen. Mit den Befehlszeilentools von Vue ist es sehr einfach, ein echtes Projekt schnell zu initialisieren.

vue init webpack my-project
Wir können sogar die Einzeldateikomponenten von Vue verwenden, die ihr eigenes HTML, JavaScript und bereichsbezogenes CSS oder SCSS enthalten. 4. MVC-, MVP-, MVVM-Entwurfsmuster

MVC (Model-View-Controller) ist eine der am weitesten verbreiteten Softwarearchitekturen und wird im Bereich der Softwareentwicklung häufig verwendet muss erklärt werden. Es ist nicht einfach, das daraus abgeleitete MVP und MVVM zu verstehen.

4.1, MVC

MVC bedeutet, dass die Software in drei Teile unterteilt werden kann:

Ansicht: Benutzeroberfläche

Controller: Geschäftslogik

Modell: Datenspeicherung
  • Die Kommunikationsmethode zwischen den einzelnen Teilen ist :
  • View sendet Anweisungen an Controller
Nachdem Controller die Geschäftslogik abgeschlossen hat, muss das Model den Status ändern

Model sendet neue Daten an View und der Benutzer erhält Feedback
  • Und die gesamte Kommunikation erfolgt in eine Richtung, da In der folgenden Abbildung dargestellt:
Es gibt zwei Möglichkeiten, das MVC-Modell auszuführen:

(1) Anweisungen über View akzeptieren und an den Controller weiterleiten

(2) Anweisungen direkt über den Controller akzeptieren

In tatsächlichen Projekten wird oft ein flexiblerer Ansatz gewählt:

(1) Der Benutzer kann Anweisungen (DOM-Ereignisse) an die Ansicht senden, und die Ansicht fordert dann direkt das Modell auf, den Status zu ändern

(2) Der Benutzer kann Anweisungen auch direkt an den Controller senden (eine Änderung der URL löst das HashChange-Ereignis aus) und der Controller sendet sie dann an die Ansicht

(3) Der Controller ist sehr dünn und spielt nur eine Routing-Rolle. Während die Ansicht sehr umfangreich ist und die gesamte Geschäftslogik in der Ansicht bereitgestellt wird, wird in einigen Frameworks der Controller direkt abgebrochen und nur ein Router beibehalten.

Wie im Bild gezeigt:

4.2, MVP

MVP (Model-View-Presenter) ist eine Weiterentwicklung des klassischen MVC. Der Modus stellt Daten bereit, die Ansicht ist für die Anzeige verantwortlich und der Präsentator ist für die logische Verarbeitung verantwortlich.

Es gibt einen großen Unterschied zwischen MVP und MVC:

  • In MVP sind Ansicht und Modell nicht miteinander verbunden. Die Kommunikation zwischen ihnen erfolgt über den Präsentator (d. h. den Controller). MVC) Intern; in MVC liest View Daten direkt vom Modell statt über den Controller.
  • Die Kommunikation zwischen verschiedenen Teilen in MVP ist bidirektional, während die Kommunikation zwischen verschiedenen Teilen in MVC unidirektional ist.
  • In MVP ist View sehr dünn und stellt keine Geschäftslogik bereit, was als „Passive View“ bezeichnet wird, das heißt, es hat keine Initiative, während Presenter sehr dick ist und die gesamte Logik dort bereitgestellt wird.

Wie im Bild gezeigt:

4.3, MVVM

MVVM (Model-View-ViewModel), das im Wesentlichen eine verbesserte Version von MVC ist und detaillierter für die Ansicht in MVC ist Arbeitsteilung. ViewModel trennt die Benutzeroberfläche der Ansicht und die Geschäftslogik. Es kann die Daten des Modells herausnehmen und dabei helfen, die in der Ansicht entworfene Geschäftslogik zu verarbeiten, da Inhalte angezeigt werden müssen.

Der MVVM-Modus ähnelt dem MVP-Modus. Der einzige Unterschied besteht darin, dass er eine bidirektionale Datenbindung (Datenbindung) verwendet, dh Änderungen in der Ansicht werden automatisch im ViewModel widergespiegelt und umgekehrt .

5. Das Prinzip der Datensteuerung (bidirektionale Datenbindung)

Was ist datengesteuert?

Datengesteuert ist das größte Merkmal von Vue.js. In Vue bedeutet das sogenannte datengesteuert, dass sich die Benutzeroberfläche entsprechend ändert, wenn sich die Daten ändern, und Entwickler das DOM nicht manuell ändern müssen.

Wenn wir beispielsweise auf eine Schaltfläche klicken, muss der Text des Elements einen „Ja/Nein“-Umschaltvorgang durchführen. In herkömmlichem jQuery besteht der Prozess der Seitenänderung normalerweise darin, das Ereignis an die Schaltfläche zu binden und dann abzurufen Kopieren Sie das entsprechende Element des Dom-Objekts und ändern Sie schließlich den Textwert des Dom-Objekts entsprechend dem Schalter.

Vue implementiert datengesteuert

Vue implementiert eine bidirektionale Datenbindung hauptsächlich durch Daten-Hijacking in Verbindung mit dem Publisher-Subscriber-Modell, indem Object.defineProperty() jede Eigenschaft entführt setter und getter veröffentlichen Nachrichten an Abonnenten, wenn sich Daten ändern, und lösen entsprechende Abhörrückrufe aus. Object.defineProperty() 来劫持各个属性的 setter 和 getter ,在数据变动时发布消息给订阅者,触发相应监听回调。

当一个普通 JavaScript 对象传给 Vue 实例来作为它的 data 选项时,vue 将遍历它的属性,用 Object.defineProperty 将它们转为 getter/setter 。用户看不到 getter/setter ,但是在内部它们让vue追踪依赖,在属性被访问和修改时通知变化。

vue的数据双向绑定将MVVM作为数据绑定的入口,整合Observer、Compile和Watcher三者,通过Observer来监听自己的Model的数据变化,通过Compile来解析编译模板指令(vue中用来解析{{}}模板语法),最终利用Watcher搭起Observer和Compile之间的通信桥梁,达到 数据变化 —> 视图更新;视图交互变化(input)—> 数据model变更 双向绑定效果。 

getter和setter的理解

当打印出vue实例下的data对象里的属性,它的每个属性都有两个对应的get和set方法。顾名思义,get为取值方法,set为赋值方法。正常情况下,取值和赋值是用 obj.prop 的方式,但是这样做有一个问题,我们如何知道对象的值改变了?

我们可以把get和set理解为function,当我们调用对象的属性时,会进入到 get.属性(){...} 中,先判断对象是否有这个属性,如果没有,那么就添加一个name属性,并给它赋值;如果有name属性,那么就返回name属性。可以把get看成一个取值的函数,函数的返回值就是它拿到的值。

当给实例赋值时,会进入 set.属性(val){...} 中,形参val就是赋给属性的值,在这个函数里做了很多事情,比如双向绑定等等。因为这个值每次都要经过set,其他方式无法对该值做修改。在ES5中,对象原型有两个属性,_defineGetter_ 和 _defineSetter_

Wenn ein normales JavaScript-Objekt als Datenoption an eine Vue-Instanz übergeben wird, durchläuft Vue seine Eigenschaften und konvertiert sie mithilfe von Object.defineProperty in Getter/Setter. Die Getter/Setter sind für den Benutzer nicht sichtbar, aber intern ermöglichen sie Vue, Abhängigkeiten zu verfolgen und Änderungen zu benachrichtigen, wenn auf Eigenschaften zugegriffen und diese geändert werden.

Vues bidirektionale Datenbindung verwendet MVVM als Eingang zur Datenbindung und integriert Observer, Compile und Watcher. Es verwendet Observer, um die Datenänderungen seines eigenen Modells zu überwachen, und verwendet Compile, um Vorlagenanweisungen zu analysieren und zu kompilieren (verwendet in vue). um die {{}}-Vorlagensyntax zu analysieren und schließlich Watcher zu verwenden, um eine Kommunikationsbrücke zwischen Observer und Compile zu bauen, um einen bidirektionalen Bindungseffekt von Datenänderungen zu erzielen -> Aktualisierungen anzeigen, interaktive Änderungen anzeigen (Eingabe) -> Datenmodelländerungen .

Verständnis von Gettern und Settern

Beim Ausdrucken der Attribute im Datenobjekt unter der Vue-Instanz verfügt jedes seiner Attribute über zwei entsprechende Get- und Set-Methoden. Wie der Name schon sagt, ist get die Wertmethode und set die Zuweisungsmethode. Unter normalen Umständen erfolgt die Werterfassung und -zuweisung mit obj.prop, es gibt jedoch ein Problem. Woher wissen wir, dass sich der Wert des Objekts geändert hat?

Wir können get und set als Funktionen verstehen. Wenn wir die Eigenschaften eines Objekts aufrufen, geben wir get.property(){...} ein und ermitteln zunächst, ob das Objekt diese Eigenschaft hat. Wenn nicht, fügen wir einen Namen hinzu Attribut und weisen Sie ihm einen Wert zu. Wenn es ein Namensattribut gibt, geben Sie das Namensattribut zurück. Sie können sich get als eine Funktion vorstellen, die einen Wert annimmt, und der Rückgabewert der Funktion ist der Wert, den sie erhält. 🎜🎜Wenn einer Instanz ein Wert zugewiesen wird, wird set.property(val){...} eingegeben. Der formale Parameter val ist der der Eigenschaft zugewiesene Wert, z. B. in beide Richtungen Bindung und so weiter. Da dieser Wert jedes Mal neu festgelegt werden muss, kann er nicht auf andere Weise geändert werden. In ES5 verfügt der Objektprototyp über zwei Attribute, _defineGetter_ und _defineSetter_, die speziell zum Binden von get und set an Objekte verwendet werden. 6. Virtueller DOM die DOM-Struktur. Diese Baumstruktur enthält Informationen über die gesamte DOM-Struktur. Vereinfacht ausgedrückt kann Virtual DOM als einfaches JS-Objekt verstanden werden und enthält mindestens drei Attribute: Tag-Name (tag), Attribute (attrs) und untergeordnete Elementobjekte (children). Verschiedene Frameworks benennen diese drei Eigenschaften unterschiedlich. 🎜 🎜🎜

6.2 Die Rolle des virtuellen DOM

Das ultimative Ziel des virtuellen DOM besteht darin, virtuelle Knoten in der Ansicht darzustellen. Wenn Sie jedoch virtuelle Knoten direkt verwenden, um alte Knoten zu überschreiben, gibt es viele unnötige DOM-Vorgänge. Beispielsweise gibt es unter einem UL-Tag viele LI-Tags, und nur eines der LI-Tags hat sich geändert. Wenn in diesem Fall ein neues UL anstelle des alten UL verwendet wird, führt dies zu einer unnötigen Leistungsverschwendung DOM-Operationen.

Um unnötige DOM-Operationen zu vermeiden, vergleicht das virtuelle DOM beim Zuordnen virtueller Knoten zu Ansichten die virtuellen Knoten mit den alten virtuellen Knoten, die beim letzten Rendern der Ansicht verwendet wurden, um herauszufinden, welche Knoten wirklich vorhanden sein müssen für DOM-Operationen aktualisiert, wodurch Operationen an anderen DOM-Elementen vermieden werden, die nicht geändert werden müssen.

Tatsächlich führt das virtuelle DOM in Vue.js hauptsächlich zwei Dinge aus:

  • Stellen Sie einen virtuellen Knoten-VNode bereit, der dem echten DOM-Knoten entspricht
  • Vergleichen Sie den virtuellen Knoten-VNode mit dem alten virtuellen Knoten oldVNode und aktualisieren Sie dann die Ansicht

6.3 Warum virtuelles DOM verwenden?

  • Es bietet plattformübergreifende Vorteile. Da Virtual DOM auf JavaScript-Objekten basiert und nicht auf die reale Plattformumgebung angewiesen ist, verfügt es über plattformübergreifende Funktionen wie Browserplattformen, Weex, Knoten usw.
  • Der Betrieb von DOM ist langsam, aber DOM-Vergleichsvorgänge können effizient auf der JS-Ebene ausgeführt werden, um die Effizienz zu verbessern. Da die Ausführungsgeschwindigkeit von DOM-Operationen weitaus langsamer ist als die von JavaScript-Operationen, wird eine große Anzahl von DOM-Operationen nach JavaScript verschoben und der Patch-Algorithmus verwendet, um die Knoten zu berechnen, die wirklich aktualisiert werden müssen, wodurch die DOM-Operationen minimiert werden die Leistung erheblich verbessern. Virtual DOM erstellt im Wesentlichen einen Cache zwischen JS und DOM. JS betreibt nur das virtuelle DOM und schreibt schließlich die Änderungen in das reale DOM.
  • Verbessern Sie die Rendering-Leistung. Der Vorteil von Virtual DOM liegt nicht in einem einzelnen Vorgang, sondern in der Möglichkeit, die Ansicht bei großen und häufigen Datenaktualisierungen angemessen und effizient zu aktualisieren.

Das obige ist der detaillierte Inhalt vonWelche Vorteile haben Vuejs für die Entwicklung?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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