首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Vue移除子组件及其状态

Vue移除子组件及其状态
EN

Stack Overflow用户
提问于 2018-09-07 21:44:26
回答 1查看 134关注 0票数 1

我想删除子组件。我使用this.rows.splice(索引,1)

当我调用this.rows.splice(index,1)时,VueJ总是从这个.$children中删除最后一个组件,并将内部状态保存在component.$data;

示例如下

代码语言:javascript
复制
`https://jsfiddle.net/abratko/gc7h1r34/3/`

如何修复它?

EN

回答 1

Stack Overflow用户

发布于 2018-09-07 22:22:11

默认情况下,Vue根据每个数据项的索引将每个数据项与每个vnode关联。这导致现有的Vue组件被重用,但绑定到不同的项,当从数组中删除项后重新呈现列表时。

这就是为什么您应该始终将key绑定到唯一标识该特定项的值。在您的示例中,由于每个项目都是唯一的字符串,因此您可以直接绑定到该字符串:

代码语言:javascript
复制
<row-component v-for="(row, index) in rows" :key="row">
                                            ^^^^^^^^^^
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52223859

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档