Vue-Komponenten geben den Wert auf folgende Weise weiter: 1. Weitergabe vom Sohn an den Vater 3. Weitergabe des Werts mit Fragezeichen, Doppelpunkt und Eltern-Kind-Komponente; . Verwenden Sie „$ref“, um den Wert zu übergeben. 6. Verwenden Sie „inject“, um die Daten der übergeordneten Komponente in die aktuelle Instanz einzufügen. 10. Wert an sessionStorage übergeben; 11. vuex.
1. Übergeben Sie die übergeordnete Komponente an die untergeordnete Komponente. Definieren Sie Requisiten in der untergeordneten Komponente, d. h. props:['msg'], msg kann ein Objekt oder ein grundlegender Datentyp sein Sie möchten einen Standardwert definieren, also props: {msg: {type: String, default: 'hello world'}},
Wenn der Standardwert ein Objekttyp ist: props: { msg: { type: Object , Standard: () => { return { name: 'dan_seek' } } }}
Es ist zu beachten, dass diese Wertübertragung nur in eine Richtung erfolgt. Sie können den Wert der übergeordneten Komponente nicht ändern (außer bei Referenztypen von natürlich); und wenn Sie den Wert von Requisiten direkt ändern, wird eine Warnung angezeigt.
Die empfohlene Schreibweise besteht darin, eine Variable in data() (siehe Children.vue) neu zu definieren und ihr Requisiten zuzuweisen. Natürlich sind auch berechnete Eigenschaften akzeptabel.
Children.vue
父组件传过来的消息是:{{myMsg}}
Parent.vue
2. Übergeben Sie die untergeordnete Komponente an die übergeordnete Komponente. Sie müssen hier ein benutzerdefiniertes Ereignis verwenden. Verwenden Sie this.$emit('myEvent'), um es in der auszulösen Untergeordnete Komponente und dann in der übergeordneten Komponente @myEvent-Überwachung in der Komponente verwenden
Children.vue
click me
Parent.vue
这里是计数:{{parentNum}}
3. Übergeben Sie Werte zwischen Geschwisterkomponenten
Verwenden Sie die Auslöse- und Überwachungsfunktionen von benutzerdefinierten Ereignissen emit, um einen öffentlichen Ereignisbus eventBus zu definieren, über den wir als Zwischenbrücke Werte an jede Komponente übergeben können. Und durch die Verwendung von eventBus können Sie Ihr Verständnis von Emission vertiefen.
EventBus.js
import Vue from 'vue'export default new Vue() Children1.vue push message
Children2.vue
children1传过来的消息:{{msg}}
Parent.vue
Es gibt auch eine Open-Source-Vue-Bus-Bibliothek auf Github, Sie können darauf verweisen: https://github.com/yangmingshan/vue -bus#readme
4. Übergeben Sie Werte zwischen Routen
i Verwenden Sie Fragezeichen, um Werte zu übergeben
Wenn Seite A zu Seite B springt, verwenden Sie dies.$router.push('/B?name=danseek' )
B-Seite kann dies $route.query.name verwenden, um den von Seite A übergebenen Wert zu erhalten.
Bitte beachten Sie den Unterschied zwischen Router und Route oben.
{ path: '/b/:name', name: 'b', component: () => import( '../views/B.vue') },
Auf Seite B können Sie diesen.$route .params.name übergeben, um den Wert des von der Route übergebenen Namens zu erhalten
iii Verwenden Sie die Eltern-Kind-Komponente, um den Wert zu übergeben
Da der Router-. Da die Ansicht selbst ebenfalls eine Komponente ist, können wir den Wert auch über die übergeordnete/untergeordnete Komponente übergeben und sie dann im entsprechenden Abschnitt zur Unterseite hinzufügen. Da die Route nach der Typaktualisierung nicht aktualisiert wird, können Sie die neueste Version nicht direkt abrufen Geben Sie value in den gemounteten Hook der Unterseite ein. Stattdessen müssen Sie watch verwenden.
// 子页面 ...... props: ['type'] ...... watch: { type(){ // console.log("在这个方法可以时刻获取最新的数据:type=",this.type) }, },
5. Verwenden Sie $ref, um einen Wert zu übergeben
Verwenden Sie die Fähigkeit von $ref, eine ID für die untergeordnete Komponente zu definieren. Über diese ID kann die übergeordnete Komponente direkt auf die Methoden und Eigenschaften zugreifen eine untergeordnete Komponente Children.vue传过来的消息:{{msg}}
push message
provide: function () { return { getName: this.getName() } }
inject: ['getName']
7. Ahnenenkel $attrs
Normalerweise müssen Sie die Requisiten des Vaters als Zwischenübergang verwenden, aber in Auf diese Weise verfügt die Vaterkomponente über mehr Dinge, die nichts mit dem Geschäft der übergeordneten Komponente zu tun haben, und kann mit Hilfe von $attrs vereinfacht werden, und es besteht keine Notwendigkeit, den Vorfahren oder Enkel zu ändern Name: Großvater
Unterkomponente erhalten
Name des Großvaters:
Geschlecht des Großvaters: Männlich
Alter des Großvaters: 88
Hobby des Großvaters: Code
8, Vorfahr des Enkels
Mit der Hilfe von. $listeners Mittlere Ereignisse, der Enkel kann Benachrichtigen Sie bequem den Vorfahren. Codebeispiele finden Sie unter 7
9, $parent
Sie können die Instanz der übergeordneten Komponente über parent abrufen und dann über diese Instanz auf die Eigenschaften und Methoden der übergeordneten Komponente zugreifen Bruder Root. Sie können die Root-Komponenteninstanz erhalten.
Syntax:
父组件传入的值:{{getName}}
Im Beispiel der Übergabe einer untergeordneten Komponente an eine übergeordnete Komponente können Sie also this.$parent.getNum(100) verwenden, um den Wert an die übergeordnete Komponente zu übergeben.
10. SessionStorage-Wertübertragung
sessionStorage ist ein globales Objekt des Browsers und die darin gespeicherten Daten werden gelöscht, wenn die Seite geschlossen wird. Mit dieser Funktion können wir eine Kopie der Daten auf allen Seiten teilen.
Syntax:
Hinweis: Es speichert Schlüssel-Wert-Paare, die nur String-Typen sein können. Wenn Sie Objekte speichern möchten, müssen Sie let objStr = JSON.stringify(obj) verwenden, um sie in Strings umzuwandeln Speichern Sie sie (verwenden Sie sie, wenn let obj = JSON.parse(objStr) in ein Objekt analysiert wird).
Ist es mühsam, solche Objekte zu speichern? Ich empfehle eine Bibliothek mit gutem Speicher, die sessionStorage kapselt, und Sie können deren API direkt zum Speichern von Objekten verwenden
父组件收到
祖父的名字:{{name}}
11, vuex
Ich werde hier nicht vorstellen, wie man dieses berühmte Vuex verwendet, da es zu lang wäre, es klar zu schreiben ...
Wenn Sie nicht vorhaben, eine große einseitige Anwendung zu entwickeln, kann die Verwendung von Vuex sinnvoll sein umständlich und überflüssig. Es stimmt – wenn Ihre App einfach genug ist, müssen Sie Vuex wahrscheinlich nicht verwenden.
Das obige ist der detaillierte Inhalt vonSo übergeben Sie einen Wert an die Vue-Komponente. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!