1
我有一個簡單的根App
,它包含兩個不同的組件Room
和Machine
。並且這些組件中的每一個都包含一個組件Datatable
,這兩個組件完全相同。要在Room
和Machine
之間切換,我使用動態組件機制,沒什麼特別的。當組件正在改變,然後我只發出事件和組件Datatable
應使用當前模塊名稱登錄到控制檯。問題在於,每次更換組件時,事件都會多次發送。如果我理解正確,在更換組件後,舊的應該被銷燬,新的創建爲什麼會發生?我使用Vue.js V.2.4.1Vue.js - 帶動態組件的多個事件
以下是部分:
App.vue:
<template>
<div id="app">
<select style="padding: 10px" v-model="currentModule" @change="changeComponent">
<option value="Room">Room</option>
<option value="Machine">Machine</option>
</select>
<component :is="currentModule"></component>
</div>
</template>
<script>
import Room from './Room.vue';
import Machine from './Machine.vue';
export default {
name: 'app',
components: {
Room,
Machine
},
data() {
return {
currentModule: 'Room'
}
},
methods: {
changeComponent: function() {
Event.$emit('moduleHasChanged', this.currentModule)
}
},
}
</script>
Machine.vue:
<template>
<div>
Machine template
<datatable></datatable>
</div>
</template>
<script>
import Datatable from './Datatable.vue';
export default {
components: {
Datatable
}
}
</script>
Room.vue:
<template>
<div>
Room template
<datatable></datatable>
</div>
</template>
<script>
import Datatable from './Datatable.vue';
export default {
components: {
Datatable
}
}
</script>
Datatable.vue
<template>
<div>
Datatable
</div>
</template>
<script>
export default {
created() {
Event.$on('moduleHasChanged', (currentModule) => {
console.log(currentModule);
})
}
}
</script>