Heim > Web-Frontend > js-Tutorial > Wertübergabeproblem von VUE2.0-Komponenten

Wertübergabeproblem von VUE2.0-Komponenten

一个新手
Freigeben: 2017-09-13 10:24:27
Original
1391 Leute haben es durchsucht

Übergabe zwischen Vue1.0-Komponenten

Verwenden Sie $on(), um auf Ereignisse zu warten
Verwenden Sie $emit(), um Ereignisse darauf auszulösen.
Verwenden Sie $dispatch(), um Ereignisse zu versenden, die entlang der übergeordneten Kette nach oben sprudeln.
Verwenden Sie $broadcast(), um Ereignisse zu übertragen, und Ereignisse werden nach unten weitergegeben an alle Nachkommen

Nach Vue2.0 sind $dispatch() und $broadcast() veraltet, siehe https://cn.vuejs.org/v2/guide/migration.html#dispatch-and-broadcast -Ersetzung

1. Wertübergabe von der untergeordneten Komponente an die übergeordnete Komponente:

Kind .vue

<template>
  <p class="child">
    <h1>子组件</h1>
    <button v-on:click="childToParent">想父组件传值</button>
  </p>
</template>
<script>
  export default{
    name: 'child',
    data(){
      return {}
    },
    methods: {
      childToParent(){
        this.$emit("childToParentMsg", "子组件向父组件传值");
      }
    }
  }
</script>parent.vue
Nach dem Login kopieren
<template>
  <p class="parent">
    <h1>父组件</h1>
    <Child v-on:childToParentMsg="showChildToParentMsg" ></Child>
  </p>
</template>
<script>
  import Child from './child/Child.vue'
  export default{
      name:"parent",
    data(){
      return {
      }
    },
    methods: {
      showChildToParentMsg:function(data){
        alert("父组件显示信息:"+data)
      }
    },
    components: {Child}
  }
</script>
Nach dem Login kopieren

2. Übergeordnete Komponente übergibt Wert an untergeordnete Komponente

parent .vue

<template>
  <p class="parent">
    <h1>父组件</h1>
    <Child v-bind:parentToChild="parentMsg"></Child>
  </p>
</template>
<script>
  import Child from './child/Child.vue'
  export default{
     name:"parent",
    data(){
      return {
        parentMsg:'父组件向子组件传值'
      }
    },
    components: {Child}
  }
</script>
Nach dem Login kopieren

child.vue

<template>
  <p class="child">
    <h1>子组件</h1>
    <span>子组件显示信息:{{parentToChild}}</span><br>
  </p>
</template>
<script>
  export default{
    name: 'child',
    data(){
      return {}
    },
    props:["parentToChild"]
  }
</script>
Nach dem Login kopieren

3. Verwenden Sie die Wertübergabe von eventBus.js – Wertübergabe zwischen Geschwisterkomponenten

eventBus.js

import Vue from &#39;Vue&#39;
export default new Vue()
Nach dem Login kopieren

App.vue

<template>
  <p id="app">
    <secondChild></secondChild>
    <firstChild></firstChild>
  </p>
</template>

<script>
import FirstChild from &#39;./components/FirstChild&#39;
import SecondChild from &#39;./components/SecondChild&#39;

export default {
  name: &#39;app&#39;,
  components: {
    FirstChild,
    SecondChild,
  }
}
</script>
Nach dem Login kopieren

FirstChild.vue

<template>
  <p class="firstChild">
    <input type="text" placeholder="请输入文字" v-model="message">
    <button @click="showMessage">向组件传值</button>
    <br>
    <span>{{message}}</span>
  </p>
</template>
<script>
  import bus from &#39;../assets/eventBus&#39;;
  export default{
    name: &#39;firstChild&#39;,
    data () {
      return {
        message: &#39;你好&#39;
      }
    },
    methods: {
      showMessage () {
       alert(this.message)        bus.$emit(&#39;userDefinedEvent&#39;, this.message);//传值
      }
    }
  }
</script>
Nach dem Login kopieren

SecondChild.vue

<template>
    <p id="SecondChild">
        <h1>{{message}}</h1>
    </p>
</template>
<script>
    import bus from &#39;../assets/eventBus&#39;;
    export default{
        name:&#39;SecondChild&#39;,
        data(){
            return {
                message: &#39;&#39;
            }
        },
        mounted(){
            var self = this;            
            bus.$on(&#39;userDefinedEvent&#39;,function(message){                
            self.message = message;//接值            
            });
        }
    }
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWertübergabeproblem von VUE2.0-Komponenten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage