Heim >Web-Frontend >View.js >Wie implementiert man die Kommunikation zwischen übergeordneten und untergeordneten Komponenten in Vue?

Wie implementiert man die Kommunikation zwischen übergeordneten und untergeordneten Komponenten in Vue?

王林
王林Original
2023-06-11 20:27:301520Durchsuche

In Vue sind Komponenten ein wichtiger Bestandteil beim Aufbau einer Benutzeroberfläche. Sie können die Benutzeroberfläche leicht in kleinere und wiederverwendbare Teile zerlegen. Da eine Seite mehrere Komponenten enthalten kann, ist die Kommunikation zwischen den Komponenten wichtig. Insbesondere die Kommunikation zwischen übergeordneten und untergeordneten Komponenten.

Vue implementiert die Kommunikation zwischen übergeordneten und untergeordneten Komponenten über props und $emit. In diesem Artikel stellen wir Ihnen beide Methoden vor.

1. Props

Props sind die Art und Weise, wie übergeordnete Komponenten in Vue Daten an untergeordnete Komponenten weitergeben. props ist ein Array, das Datenattribute speichert, die an untergeordnete Komponenten übergeben werden sollen. Verwenden Sie in der untergeordneten Komponente Requisiten, um von der übergeordneten Komponente übergebene Daten zu empfangen.

Verwendung von Requisiten: Definieren Sie zunächst Requisiten in der übergeordneten Komponente. Der Code lautet wie folgt:

<template>
  <child :message="parentMsg"/>
</template>

<script>
import Child from "./Child.vue";
export default {
  data() {
    return {
      parentMsg: "父组件的数据",
    };
  },
  components: {
    Child,
  },
  props: ["parentMsg"], //在父组件中定义props
};
</script>

Im obigen Code übergibt die übergeordnete Komponente über Requisiten eine Eigenschaft mit dem Namen message an die untergeordnete Komponente.

Dann empfangen Sie Requisiten in der untergeordneten Komponente:

<template>
  <h2>{{ message }}</h2>
</template>

<script>
export default {
  props: {
    message: {
      type: String,
      required: true, //props接收的属性必须有值
    },
  },
};
</script>

In der untergeordneten Komponente wird das von der übergeordneten Komponente übergebene Nachrichtenattribut über Requisiten empfangen.

Zu diesem Zeitpunkt wird der Wert „Daten der übergeordneten Komponente“ auf der Seite der übergeordneten Komponente angezeigt.

2. $emit

$emit ist die Art und Weise, wie untergeordnete Komponenten in Vue Nachrichten an übergeordnete Komponenten weiterleiten. Wenn bestimmte Ereignisse in einer untergeordneten Komponente auftreten, kann die Ereignismethode der übergeordneten Komponente über $emit ausgelöst werden. Der erste Parameter der Methode $emit ist der Name des auszulösenden Ereignisses und der zweite Parameter ist der Parameter, der an die übergeordnete Komponente übergeben werden soll.

Verwendung von $emit: Definieren Sie zunächst eine Ereignismethode in der untergeordneten Komponente. Rufen Sie die Methode $emit auf, um die Nachricht an die übergeordnete Komponente zu übergeben Code, die untergeordnete Komponente definiert die Ereignismethode onClick. Wenn auf die Schaltfläche geklickt wird, wird das Ereignis namens child-msg über die Methode $emit ausgelöst und der Parameter „Daten der untergeordneten Komponente“ übergeben.

Dann hören Sie sich dieses Ereignis in der übergeordneten Komponente an:

<template>
  <button @click="onClick">点击传递消息到父组件</button>
</template>

<script>
export default {
  methods: {
    onClick() {
      this.$emit("child-msg", "子组件的数据");
    },
  },
};
</script>

Im obigen Code verwendet die übergeordnete Komponente das @-Symbol, um das Ereignis der untergeordneten Komponente abzuhören. Sobald die untergeordnete Komponente das Ereignis „child-msg“ auslöst, reagiert die übergeordnete Komponente auf das Ereignis und empfängt die von der untergeordneten Komponente über die Methode „getChildMsg“ übergebenen Daten und zeigt die Daten dann auf der Seite an.

Durch die beiden oben genannten Methoden kann in Vue die Kommunikation zwischen übergeordneten und untergeordneten Komponenten erreicht werden. Der Code ist prägnant, leicht verständlich und leicht zu warten, was die Effizienz der Komponentenentwicklung verbessern kann.

Das obige ist der detaillierte Inhalt vonWie implementiert man die Kommunikation zwischen übergeordneten und untergeordneten Komponenten in Vue?. 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