Ich habe angefangen zu spielen mit Vue
, aber ein Problem beim Versuch, Daten an eine Komponente mit props
übergeben. In dem folgenden Code this.myData
(im Hello.vue
) ist undefined
aus irgendeinem GrundVuejs - Daten von Eltern zu Kind mit Requisiten übergeben
App.vue
<script>
import Hello from './components/Hello'
export default {
name: 'app',
data() {
return {
myData: 'this is my data'
}
},
components: {
Hello
} ...
</script>
Hello.vue
<script>
export default {
name: 'hello',
props: ['myData'],
data() {
return {
msg: 'Welcome to Your Vue.js App'
}
}
mounted: function() {
console.log(this.myData)
}
} ...
</script>
Ja auf diese Weise funktioniert. Also sollten die Daten immer durch die Vorlage gehen? Was passiert, wenn ich nur Daten übergeben möchte, ohne sie tatsächlich zu rendern (zum Beispiel einige Konfigurationseinstellungen)? –
Es gibt Möglichkeiten, um den Datenaustausch zwischen Komponenten zu erreichen, die kein Template-Rendering benötigen, wie zum Beispiel einen 'eventBus' oder einen vuex-Store. Für Ihren Fall scheinen Requisiten der beste Weg zu sein und Sie müssen das Kind rendern Komponente in der Vorlage. Es gibt einen Weg, Ill aktualisieren meine Antwort dafür, aber das ruft die Render-Funktion. Scheint das in Ordnung? –
Danke! Ich habe nichts dagegen, Requisiten zu benutzen. Scheint der richtige Weg, es zu tun. Haben Sie einfach nicht herausgefunden, dass die Daten über die Vorlagen übertragen werden. –