Vue中key的原理以及diff算法詳解
Vue中key的原理以及diff算法
簡介
Vue的key用于在虛擬DOM中標記節(jié)點,方便后面的diff對比算法進行對比,提升效率。
Vue的vm或者vc實例一共管理著3個DOM對象
分別他的模板對應的真實DOM、真實DOM的備份、以及重新生成的新的DOM,后兩個可以看成是虛擬DOM,只要后面兩個DOM的DOM樹的葉子或者節(jié)點不一樣(被指令操作虛擬DOM進行了修改),那么就會通過渲染函數(shù)render重新更新HTML頁面上的真實DOM。
使用列表渲染時
會生成新的節(jié)點,這些節(jié)點不是一開始在模板當中寫的,屬于后來的DOM節(jié)點,所以需要特殊管理。
列表渲染新生成的DOM節(jié)點一般是一棵子DOM樹
使用key可以記錄這棵子樹的根節(jié)點,diff差分算法就是根據(jù)從這個子樹的根節(jié)點開始進行對比,判斷DOM節(jié)點是否發(fā)生變化。
- 如果發(fā)現(xiàn)key不存在,直接創(chuàng)建新的子樹。
- 如果key存在,則會對子樹遍歷。但是對于一些在HTML中的真實DOM中存在的內(nèi)容,比如input框里面的內(nèi)容,Vue是不知道的,因為Vue只有一開始真實DOM的備份,后面這個HTML頁面上的真實DOM發(fā)生了什么變化Vue是不知道的。這就會導致真實DOM的一部分被替換掉,而另外一部分還是殘留的老的真實DOM。
如果遍歷容器時
使用index作為key,則會出現(xiàn)部分真實DOM殘留的問題。實際開發(fā)中,一般使用獨一無二的index作為key。
總結(jié)如下
- 最好使用每條數(shù)據(jù)的唯一標識作為key,比如id、手機號、身份證號、學號等唯一值
- 如果不存在對數(shù)組數(shù)據(jù)的逆序添加、逆序刪除等破壞順序的操作,僅用于渲染列表,使用index作為key是沒有問題的
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
vue中el-table和jsplumb實現(xiàn)連線功能
本文主要介紹了el-table和jsplumb實現(xiàn)連線功能,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-07-07