Vue 中列表循環渲染是一個常用的場景,在使用中常常需要給每個元素設置 key 屬性,使 Vue 在進行 diff 算法的時候能夠準確地跟蹤每個列表項的變化。
在 Vue 應用中,每個組件都有一個全局唯一的標識符,在 Vue 的實現中,我們可以把它稱為 vnode。在每次更新渲染時,Vue 會通過比較新舊 vnode,來決定頁面上到底是通過 Dom 操作刪除、插入還是更新。
在列表循環中,如果 Vue 沒有指定 key 值,那么在每次更新時就會出現一些意外的行為。例如,當我們在列表的開頭插入一個元素時,列表本來應該是整體往后移動一個位置,但如果沒有指定 key 值,那么 Vue 就會出現這個新插入元素和列表第二個元素重復的問題。
為了避免這種意外行為,我們需要為每個列表項設置一個唯一且穩定的 key 值。
- {{ item.name }}
上面的代碼中,我們將列表項的 key 屬性綁定到了每個列表項的 id 屬性上,這樣每次更新渲染時,Vue 就能夠準確地跟蹤每個列表項的變化,從而避免列表循環中出現意外行為。
需要注意的是,key 值必須是一個字符串或數字類型,不能是對象或數組,否則會收到 Vue 中 key 值無效的報錯信息。
另外,為了保持 key 值唯一的穩定性,建議不要使用列表中每個元素的下標 index 作為 key 值,在某些特殊情況下,可能會造成列表項重復渲染或不渲染的問題。
總之,在 Vue 中,為列表循環生成唯一且穩定的 key 值是非常重要的,不僅可以提高應用的性能,更可以避免不必要的意外行為。
上一篇vue 加載公用css
下一篇vue 列表選中刪除