Vue.js是一種雙向數據綁定實現的JavaScript框架。在Vue.js中,可以使用key屬性來控制虛擬DOM的行為。key是一種特殊的屬性,用于給VNode做唯一標識,可以方便VNode的復用和定位。
在Vue.js中,當組件被重新渲染時,會創建一顆新的虛擬DOM樹。Vue.js會根據新的虛擬DOM樹和舊的虛擬DOM樹的差異來更新真實的DOM樹。如果兩棵虛擬DOM樹中的某個節點的key值相同,則Vue.js會認為這個節點是相同的,會嘗試復用這個節點而不是重建一個新節點。
// 關鍵代碼示例 // 在 v-for 中必須指定 key,否則會報錯
- {{ item.name }}
在使用v-for指令循環渲染時,也需要給每個渲染的元素添加key屬性,這樣Vue.js才可以在進行DOM更新時基于key值精準地重新渲染每個元素。在使用v-for指令循環渲染時,key的建議用法是使用每個元素的唯一標識,例如數據庫中的主鍵或者全局唯一的隨機數。
需要注意的是,在Vue.js 2.x版本中,當使用相同對象的數組進行v-for指令渲染時,如果對象屬性發生改變,不會觸發DOM的重渲染,需要手動更新對象引用來觸發DOM更新。而在Vue.js 3.x 版本中,這個問題被優化,會自動檢測對象變化,無需手動更新引用即可觸發DOM更新。