Heim >Web-Frontend >js-Tutorial >Wird aus Vue Low eine Reaktion? (Ich bin ehrlich gesagt verwirrt.)

Wird aus Vue Low eine Reaktion? (Ich bin ehrlich gesagt verwirrt.)

Susan Sarandon
Susan SarandonOriginal
2025-01-13 20:41:51347Durchsuche

Vue lowly Turning Into React? (I

Ich bin schon lange ein großer Fan von Vue. Ich erinnere mich, als ich es zum ersten Mal benutzte, war die Einfachheit ein Hauch frischer Luft, insbesondere im Vergleich zu den React-Projekten, mit denen ich gerungen hatte. Vue 2 schien eine klare Philosophie zu haben: Seien Sie zugänglich, unkompliziert und lassen Sie Entwickler sich auf die Anwendung und nicht auf das Framework selbst konzentrieren.

Aber in letzter Zeit verbringe ich mehr Zeit mit Vue 3, und mal ehrlich? Ich bin etwas verwirrt. Ich fange an, einige Muster zu erkennen, die mir furchtbar vertraut vorkommen, und das nicht im positiven Sinne. Es ist, als ob ich anfange zu sehen, wie sich Vue 3 langsam in etwas verwandelt, das React ähnelt.

Nun, ich versuche nicht, Vue 3 zu verunglimpfen. Es verfügt über eine Menge toller Funktionen und die Kompositions-API ist leistungsstark. Aber ich werde das Gefühl nicht los, dass wir einige der Kernprinzipien verlieren, die Vue überhaupt erst so einzigartig gemacht haben.

Der „Vue Way“: Was wir geliebt haben

Seien wir ehrlich. Ein großer Teil der Attraktivität von Vue, insbesondere Vue 2, war seine Benutzerfreundlichkeit. Sie hatten die unkomplizierte Options-API. Es war eine Freude, mit den Vorlagen zu arbeiten. einfach und intuitiv. Sie könnten eine Vue-App schnell starten, ohne sich durch komplexe Konfigurationen wühlen zu müssen. Das Ökosystem fühlte sich überschaubar an; Sie hatten einen soliden Router (vue-router) und ein Zustandsverwaltungsmuster (vuex), und das war’s! Mit Vue können Sie sehr effizient arbeiten.

Hier ist ein einfaches Beispiel einer Vue 2-Komponente:

<template>
  <div>
    <p>{{ message }}</p>
    <button @click="reverseMessage">Reverse</button>
  </div>
</template>

<script>
export default {
  data() {
    return {
      message: "Hello Vue 2!",
    };
  },
  methods: {
    reverseMessage() {
      this.message = this.message.split("").reverse().join("");
    },
  },
};
</script>

Einfach. Direkt. Leicht zu verstehen. Das war das Vue-Versprechen.

Der Wandel: Als sich die Dinge ... anders anfühlten

Aber mit Vue 3 begannen sich die Dinge zu ändern. Die Einführung der Composition API ist zwar leistungsstark, bringt aber ein völlig anderes mentales Modell mit sich. Es fühlt sich... abstrakt an. Plötzlich erfordern einfache Aufgaben mehr Code. Sie können in beiden APIs die gleichen Dinge tun, aber in manchen Situationen fühlt sich die Komplexität unangebracht an.

Hier ist ein Beispiel derselben Komponente in Vue 3 unter Verwendung der Composition API:

<template>
  <div>
    <p>{{ message }}</p>
    <button @click="reverseMessage">Reverse</button>
  </div>
</template>

<script setup>
import { ref } from 'vue';

const message = ref("Hello Vue 3!")

function reverseMessage() {
  message.value = message.value.split("").reverse().join("");
}
</script>

Es macht das Gleiche, aber... fühlt es sich nicht nach mehr Arbeit an? Schauen Sie sich an, dass jetzt selbst eine einfache Nachrichtenvariable eine Referenz und einen Wert benötigt, um auf ihren Inhalt zuzugreifen! Es ist ein bisschen viel für etwas, das bisher unkompliziert war.

Und es ist nicht nur die Kompositions-API. Auch der staatliche Verwaltungsbereich ist komplizierter geworden. Wir haben jetzt Pinia, was großartig ist, aber jetzt müssen wir eine andere Wahl treffen. Es fängt an, sich wie eine „reaktionsartige“ Komplexität anzufühlen, bei der es keine einheitliche Vorgehensweise gibt und der Entwickler vor dem Codieren viele Entscheidungen treffen muss.

Ich fange auch an, einige Vue-3-Projekte zu sehen, die das Gefühl haben, dass sie völlig aus dem Ruder gelaufen sind, mit komplizierten Setups und Abstraktionsebenen für Projekte, die vielleicht nur die Grundlagen benötigen. Es ist wie bei React, wo Sie eine Hallo-Welt mit 10 Bibliotheken sehen.

Das wachsende Ökosystem und die Wahlmöglichkeiten

Ich kann nicht umhin, das Wachstum des Vue-Ökosystems zu bemerken. Es scheinen ständig neue Tools und Bibliotheken aufzutauchen, was sowohl aufregend als auch überwältigend ist.

Es lässt mich an ein Gefühl denken, das viele von uns React-Entwicklern haben: „Optionslähmung“. Und ich fange an, es mit Vue 3 zu spüren:

  • Soll ich Pinia oder Vuex verwenden?

  • Welche Testprogramme sollte ich verwenden?

  • Soll ich einfach alles von Grund auf neu erstellen oder eine große Komponentenbibliothek übernehmen?

Das war etwas, von dem ich dachte, ich hätte es hinter mir gelassen, als ich zu Vue wechselte...

Bin ich verrückt?

Ich weiß, ich weiß. Vielleicht übersehe ich einfach etwas. Vielleicht sind diese Änderungen alle notwendig, damit Vue wachsen und sich anpassen kann. Vielleicht liegt es nur an mir und meinen Vorlieben.

Aber ich werde das Gefühl nicht los, dass der Kernreiz von Vue – seine Einfachheit, seine Klarheit, sein „einfach funktioniert“-Charakter – ein wenig untergraben wird. Ich mache mir Sorgen, dass wir langsam aber sicher ein Vue-Ökosystem aufbauen, das eher wie React aussieht und sich auch so anfühlt. Es kommt einem so vor, als würden wir die einzigartige Identität von Vue verlieren.

Also, was denkst du? Bin ich damit allein? Sehen Sie die gleichen Trends? Ich würde gerne Ihre Meinung hören. Vielleicht brauche ich einfach jemanden, der mich davon überzeugt, dass ich falsch liege, oder vielleicht geht es uns allen ein bisschen ähnlich.

Lass uns in den Kommentaren diskutieren!

Das obige ist der detaillierte Inhalt vonWird aus Vue Low eine Reaktion? (Ich bin ehrlich gesagt verwirrt.). 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