我的vscode在vuejs v中需要这个属性,如
坏的
<p v-for='person in people'> {{person.name}} </p>
好的
<p v-for='(person, index) in people' :key='index'> {{person.name}} </p>
那么,为什么我们需要:关键属性呢?
发布于 2017-11-20 15:40:37
发布于 2019-01-05 06:10:08
假设数组中有项目列表。
v-for
如果我们使用v-for,它将根据它们的索引显示所有这些项。VueJ没有跟踪所有这些元素。每当对项进行任何更改时,VueJs将根据数组中项的索引替换dom中的位置。(只是替换而不是移动元素),它只是修补或替换位置(在dom中)。它不存储任何array.It项的值,不跟踪项的值。它只存储索引位置。
这方面的问题是,有时vuejs数组中的任何更改都不能根据我们的需要进行更新(请记住,在某些情况下)。如果我们希望我们的vuejs能够跟踪数组中的那些项,该怎么办。这就是:key出现在图片中的地方。
:key
现在,当我们提到关键属性(如item.id等)时,在v-for vuejs中,将直接引用这些项目。记住,vuejs不是存储位置,而是存储项目。Vuejs将跟踪数组中的所有这些项。无论何时对项进行任何更改,它都将更改dom中的那些项。(通过在dom中移动元素来更改这些项) : key 只需确保vuejs跟踪所有这些项。(每个key属性都像id一样。无论什么时候发生变化,vuejs都会使用更新的值。)
作为最终用户,我们看不到输出方面的差别(如果我们不提及:key),但是在后台会发生这样的事情。
通过这个,你肯定会发现不同的。用键控制可重用元素
https://stackoverflow.com/questions/47395535
复制相似问题