Virtual DOM 算法——虛擬DOM

虛擬DOM:將真實DOM樹上的結(jié)構(gòu)、屬性信息等用JavaScript 對象的形式來表示
栗子:
HTML寫法:

<ul id='list'>
  <li class='item'>Item 1</li>
  <li class='item'>Item 2</li>
  <li class='item'>Item 3</li>
</ul>

對應(yīng)JavaScript 對象表示

var element = {
  tagName: 'ul', // 節(jié)點標(biāo)簽名
  props: { // DOM的屬性,用一個對象存儲鍵值對
    id: 'list'
  },
  children: [ // 該節(jié)點的子節(jié)點
    {tagName: 'li', props: {class: 'item'}, children: ["Item 1"]},
    {tagName: 'li', props: {class: 'item'}, children: ["Item 2"]},
    {tagName: 'li', props: {class: 'item'}, children: ["Item 3"]},
  ]
}

Virtual DOM 算法:當(dāng)狀態(tài)變更時,比較兩棵新舊虛擬DOM樹的差異(核心部分:diff算法),將找出的差異部分進(jìn)行DOM操作

簡單總結(jié):
1、構(gòu)建虛擬DOM
2、通過虛擬DOM構(gòu)建真實DOM
3、生成新的虛擬DOM
4、diff算法比較兩顆虛擬DOM的差異

1)只會對同一個層級的元素進(jìn)行對比
2)深度優(yōu)先遍歷,記錄差異
3)差異類型
可能出現(xiàn)的DOM操作:節(jié)點替換、刪除、新增、修改、更改列表順序等
因為節(jié)點是可重復(fù)的,所以需要給子節(jié)點加上唯一標(biāo)識key,列表對比的時候,使用key進(jìn)行對比,這樣才能復(fù)用老的 DOM 樹上的節(jié)點,記錄下每個節(jié)點的差異

5、真實DOM上只應(yīng)用變更記錄下來的差異部分即可

來自:https://github.com/livoras/blog/issues/13

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容