簡體   English   中英

Vue.js $發出事件觸發但沒有發生任何事情

[英]Vue.js $emit Event Triggering But Nothing Happens

我試圖從Vue中的子組件調用$ emit事件來觸發App.vue中的函數。 事件根據Vue檢查器觸發,DOM檢查器顯示DIV設置為觸發事件,但沒有任何反應。

我已經嘗試重命名事件,確保函數在click事件上工作,綁定到不同的組件和div,並且不包括事件的有效負載。 似乎沒什么用。 我已經嘗試了Firefox和Chrome,兩者都以相同的結果結束:被叫事件沒有發生任何事情。

子組件和方法

<div class="navbutton" v-on:click="clicked(data.id)">
  <p>{{data.text}}</p>
</div>
clicked(id){
switch(id){
    case 1:
       alert("One");
       break;
    case 2:
        this.$emit('testemit');
        break;
    case 3:
        alert("Three");
        break;
    case 4:
        alert("Four");
        break;
    default:
        alert("DEFAULT");
        break;
    }
}

來自App.vue

<div v-on:testemit="EmitFunction"></div>
EmitFunction() {
    alert('MESSAGE');
}

我希望在點擊第二個按鈕時收到一條警告“MESSAGE”,但沒有任何反應。 其他三個按鈕(1,3和4)可正常工作。

你需要實際激活一個emit並監聽父組件,如下所示:

//app.vue
<template>
  <my-component v-on:testemit="EmitFunction"/>
</template>

並且你的'EmitFunction()'在你的方法中做你'點擊'正在做的事情。

methods: {
  EmitFunction(id) {
    switch... etc

在你的組件中......

//myComponent.vue
<div class="navbutton" v-on:click="$emit('testemit', id)">
  <p>{{data.text}}</p>
</div>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM