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