Vue删除子组件的状态

问题描述 投票:1回答:1

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

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

示例在这里

`https://jsfiddle.net/abratko/gc7h1r34/3/`

如何解决?

vue.js components
1个回答
1
投票

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

这就是为什么你应该总是将key绑定到唯一标识该特定项的值。在您的示例中,由于每个项都是唯一的字符串,您只需绑定到该项:

<row-component v-for="(row, index) in rows" :key="row">
                                            ^^^^^^^^^^
© www.soinside.com 2019 - 2024. All rights reserved.