У меня есть два следующих компонента:
Vue.component('comp-child', {
template: `<div>{{childData.name}}<slot></slot>{{randomNum}}</div>`,
props: {
parentData: {
}
},
data() {
return {
childData: {},
randomNum: Math.round(Math.random() * 100)
};
},
created() {
this.childData.name = this.parentData.name;
}
});
Vue.component('comp-parent', {
template: `<div><component v-for="(item, index) in arr" is="comp-child" :key="index" :parent-data="item">
<button @click="deleteItem(index)">delete</button>
</component>
</div>`,
data(){
return {
arr: [{
name:1
}, {
name:2
}, {
name:3
}, {
name:4
}, {
name:5
}]
};
},
methods: {
deleteItem(index) {
this.arr.splice(index, 1);
console.log(`${index}th element deleted! `);
}
}
});
let app = new Vue({
el: '#app'
});
<script src="https://unpkg.com/vue"></script>
<div id="app">
<comp-parent></comp-parent>
</div>
В этой демонстрации, независимо от того, какой элемент вы щелкнете, всегда удаляется последний элемент.
Я обнаружил эту проблему, вызванную key
из v-for
, если использовать 1, 2, 3, 4,..
в качестве ключа, эта проблема возникает, но используйте другое значение как ключ, например строку, он просто отлично работает;
template: `<div><component v-for="(item, index) in arr" is="comp-child" :key="item.key" :parent-data="item">
<button @click="deleteItem(index)">delete</button>
</component>
</div>`,
data(){
return {
arr: [{
name:1,
key: 'key1'
}, {
name:2,
key: 'key2'
}, {
name:3,
key: 'key3'
}, {
name:4,
key: 'key4'
}, {
name:5,
key: 'key5'
}]
};
},
проверьте эту скрипку: демонстрация
Это вызвано виртуальным DOM? Кажется, что VUE связывает ключ и дочерние компоненты как кеш, когда arr
изменяется, он просто повторно отображает компоненты в порядке index (1,2,3, ..), если какой-то элемент в arr
удален, длина arr
уменьшается потому что последний не может быть отрисован.
Пожалуйста, объясните мне это, спасибо!