Heim >Web-Frontend >js-Tutorial >Wie aktualisiere ich übergeordnete Daten einer untergeordneten Komponente in Vue.js?

Wie aktualisiere ich übergeordnete Daten einer untergeordneten Komponente in Vue.js?

Susan Sarandon
Susan SarandonOriginal
2024-10-28 07:15:02239Durchsuche

How to Update Parent Data from a Child Component in Vue.js?

Aktualisieren der übergeordneten Daten von der untergeordneten Komponente in Vue.js

In Vue.js ermöglicht die bidirektionale Bindung, dass untergeordnete Komponenten die direkt mutieren Eigenschaften ihrer übergeordneten Komponenten. Mit der Veröffentlichung von Vue 2.0 wurde die bidirektionale Bindung jedoch zugunsten einer ereignisgesteuerten Architektur veraltet.

Lösung: Ereignisgesteuerte Kommunikation

In Bei diesem Ansatz löst die untergeordnete Komponente Ereignisse mit dem aktualisierten Wert aus. Die übergeordnete Komponente wiederum verarbeitet diese Ereignisse und ändert ihre Daten entsprechend. Erstellen wir beispielsweise eine benutzerdefinierte untergeordnete Komponente mit einer Texteingabe:

<code class="javascript">Vue.component('child', {
  template: '#child',
  props: ['value'],
  methods: {
    updateValue(value) {
      this.$emit('input', value);
    }
  }
});</code>

Aktualisierung des übergeordneten Werts

In der untergeordneten Komponente wird die updateValue-Methode immer aufgerufen Der Eingabewert ändert sich. Diese Methode gibt ein „Eingabe“-Ereignis aus und übergibt den aktualisierten Wert als Argument.

Auf Ereignisse in der übergeordneten Instanz warten

In der übergeordneten Vue-Instanz:

<code class="javascript">new Vue({
  el: '#app',
  data: {
    parentValue: 'hello'
  },
  methods: {
    handleInput(value) {
      this.parentValue = value;
    }
  }
});</code>

Bindung mit V-Modell

Vue.js bietet eine praktische Abkürzung für die bidirektionale Bindung namens V-Modell. Durch die Verwendung von v-model für ein Formularelement wird dieses automatisch an die angegebene Eigenschaft in der übergeordneten Komponente gebunden. Der folgende Code veranschaulicht dies:

<code class="html"><child v-model="parentValue"></child></code>

In diesem Beispiel ist die Value-Eigenschaft der untergeordneten Komponente an die parentValue-Eigenschaft in der übergeordneten Komponente gebunden. Änderungen an der Eingabe in der untergeordneten Komponente aktualisieren automatisch den parentValue in der übergeordneten Komponente.

Das obige ist der detaillierte Inhalt vonWie aktualisiere ich übergeordnete Daten einer untergeordneten Komponente in Vue.js?. 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