Работаю над исправлением ошибки в чужом коде, поэтому я пытаюсь ограничить то, что я должен изменить здесь.
Похоже, когда я использую функциональность $emit
для запуска функций между дочерними и родительскими компонентами , в моих компонентах потеряна привязка v-модели.
Есть родительский компонент:
ParentComponent. vue
<template>
<child-component v-bind:items="this.items"
v-on:event_child="this.eventUpdater">
</child-component>
<template>
<script>
import ChildComponent from './ChildComponent.vue';
export default {
components: {
'child-component': ChildComponent
},
methods: {
getItemDetails() {
//...ajax request that loads item details for page.
},
eventUpdater: function(id) {
this.getItemDetails();
}
}
}
</script>
Затем есть дочерний компонент:
ChildComponent. vue
<template>
<div v-for="item in items">
<input v-model="item.itemId">
</div>
<button v-on:click="updateItems">update</button>
</template>
<script>
export default {
props: ['items'],
methods: {
updateItems() {
//...ajax call that updates items.
this.emitWhat();
},
emitWhat: function () {
this.$emit('event_child');
}
}
}
</script>
После обновления моего исходного элемента (который обновляется нормально), я go до обновите другой элемент, и кажется, что v-модель для этого элемента не работает. Не нарушает ли функциональность $emit
привязку v-модели после первоначальной загрузки? Как мне это исправить?