Heim >Web-Frontend >js-Tutorial >Informationen zur Verwendung von Vue-High-Level-Komponenten

Informationen zur Verwendung von Vue-High-Level-Komponenten

亚连
亚连Original
2018-06-13 11:45:522495Durchsuche

In diesem Artikel wird hauptsächlich die Verwendung von Vue-High-Level-Komponenten vorgestellt. Jetzt teile ich ihn mit Ihnen und gebe Ihnen eine Referenz.

Komponenten höherer Ordnung (HOC) sind im React-Ökosystem üblich. Die Hauptmethode zur Wiederverwendung von Code in React ist die Verwendung von Komponenten höherer Ordnung, und dies wird auch offiziell empfohlen Ansatz. Die Hauptmethode zur Wiederverwendung von Code in Vue ist die Verwendung von mixins, und das Konzept von Komponenten höherer Ordnung wird in Vue selten erwähnt. Dies liegt daran, dass die Implementierung von Komponenten höherer Ordnung in Vue nicht mit ist so einfach wie in React, da die Designideen von React und Vue unterschiedlich sind. Dies bedeutet jedoch nicht, dass Komponenten höherer Ordnung nicht in Vue verwendet werden können, sondern die Verwendung von Komponenten höherer Ordnung in Vue führt zu keiner qualitativen Einkommensveränderung im Vergleich zu mixins. In diesem Artikel wird hauptsächlich die Implementierung von Vue Komponenten höherer Ordnung aus technischer Sicht erläutert und aus den beiden Perspektiven React und Vue analysiert.

Ausgehend von React

Zuerst React auch verwendet mixins, um beispielsweise unnötiges wiederholtes Rendern von Komponenten zu vermeiden kann PureRenderMixin in die Komponente einmischen:

const PureRenderMixin = require('react-addons-pure-render-mixin')
const MyComponent = React.createClass({
 mixins: [PureRenderMixin]
})

Später React wurde diese Methode aufgegeben und shallowCompare verwendet:

const shallowCompare = require('react-addons-shallow-compare')
const Button = React.createClass({
 shouldComponentUpdate: function(nextProps, nextState) {
 return shallowCompare(this, nextProps, nextState);
 }
})

Dies erfordert, dass Sie die shouldComponentUpdate-Methode selbst in der Komponente implementieren . Es ist nur so, dass shallowCompare Ihnen bei der spezifischen Arbeit dieser Methode hilft, also ein oberflächlicher Vergleich.

und später React Um zu vermeiden, dass Entwickler immer den gleichen Code in Komponenten schreiben müssen, wird empfohlen, React.PureComponent zu verwenden. Kurz gesagt, React löst sich von mixins Schritt für Schritt denken sie, dass mixins kein gutes Modell im React-Ökosystem ist (Hinweis: Es heißt nicht, dass mixins schlecht ist, nur für das React-Ökosystem. Die Ansichten sind wie folgt:

1, mixins bringt implizite Abhängigkeiten mit sich

2. Zwischen mixins und mixins kann es leicht zu Namenskonflikten zwischen mixins und Komponenten

3 kommen . Da mixins aufdringlich ist, ändert es die ursprüngliche Komponente, sodass das Ändern von mixins dem Ändern der ursprünglichen Komponente entspricht. Mit zunehmender Nachfrage wird mixins komplex, was zu einer Schneeballkomplexität führt.

Weitere Informationen finden Sie in diesem Artikel: Mixins gelten als schädlich. Allerdings ist HOC kein Allheilmittel. Es bringt natürlich seine eigenen Probleme mit sich. Der Punkt ist: Die Verwendung gewöhnlicher Komponenten mit render prop kann alles bewirken, was HOC kann.

Ich habe das Obige für Sie zusammengestellt und hoffe, dass es Ihnen in Zukunft hilfreich sein wird.

Verwandte Artikel:

jQuery implementiert eine rekursive unendliche Ebenenfunktion

So implementieren Sie ein Verantwortungskettenmuster in JavaScript

Verwenden Sie Ajax und Jquery, um die sekundäre Verknüpfung des Dropdown-Felds zu realisieren

Verwandte Probleme mit dem Vue-awesome-swiper-Plug-in

vue So verwenden Sie das Better-Scroll-Plug-in

So erhalten Sie den angegebenen Indexwert mit jquery

Entwicklung verwandter Warenkomponenten im Vue-Framework

Die erste Verwendung der Stiftinstallationsmethode in Vue (ausführliches Tutorial)

Vergleich der Verwendung von Express und Koa (ausführliches Tutorial)

Bezahlte Online-Kurse in Vue (ausführliches Tutorial)

Das obige ist der detaillierte Inhalt vonInformationen zur Verwendung von Vue-High-Level-Komponenten. 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