vue的虛擬dom

為什么用vue

1.操作dom元素需要把html結(jié)構(gòu)銷毀之后,然后再進(jìn)行重新生成,十分消耗性能

2.虛擬dom,通過(guò)diff算法,減少性能的消耗
vue通過(guò)建立一個(gè)虛擬DOM樹(shù)對(duì)真實(shí)DOM發(fā)生的變化保持追蹤。

一棵真實(shí)DOM樹(shù)的渲染需要先解析CSS樣式和DOM樹(shù),然后將其整合成一棵渲染樹(shù),再通過(guò)布局算法去計(jì)算每個(gè)節(jié)點(diǎn)在瀏覽器中的位置,最終輸出到顯示器上,
而虛擬DOM則可以理解為保存了一棵DOM樹(shù)被渲染之前所包含的所有信息,而這些信息可以通過(guò)對(duì)象的形式一直保存在內(nèi)存中,并通過(guò)JavaScript的操作進(jìn)行維護(hù)。

用傳統(tǒng)jquery操作dom的思想,可以先刪除,然后再插入新的標(biāo)簽

虛擬dom會(huì)如何處理上述問(wèn)題呢?

第一步:通過(guò)樹(shù)的形式保存舊的dom信息,這些信息可能在頁(yè)面第一次加載的時(shí)候被渲染到瀏覽器中,但仍是通過(guò)虛擬dom的方式創(chuàng)建的

第二步:檢測(cè)到數(shù)據(jù)更新,需要更新dom,先在JavaScript中將需要修改的節(jié)點(diǎn)全部修改完成(這個(gè)步驟可以進(jìn)行算法上的優(yōu)化,會(huì)在后面的原理中詳細(xì)說(shuō)明)

第三步:將最終生成的虛擬DOM更新到視圖中去。

需要付出的代價(jià)付出的只是在你的內(nèi)存中需要保存一份可供維護(hù)的數(shù)據(jù)信息

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

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

  • ###vue的虛擬DOM和diff原理 Vue的核心是雙向綁定和虛擬DOM(下文我們簡(jiǎn)稱為vdom),vdom是樹(shù)...
    鋒享前端閱讀 1,505評(píng)論 0 1
  • 參考文章:深度剖析:如何實(shí)現(xiàn)一個(gè)Virtual DOM 算法 作者:戴嘉華React中一個(gè)沒(méi)人能解釋清楚的問(wèn)題——...
    waka閱讀 6,163評(píng)論 0 21
  • 就是單純發(fā)個(gè)文字,就是單純發(fā)個(gè)文字。就是單純發(fā)個(gè)文字。
    Akunna閱讀 152評(píng)論 2 0
  • 春天的雨是不張揚(yáng)的,樸素的,她來(lái)時(shí)悄無(wú)聲息,無(wú)知無(wú)覺(jué),即使是連夜的下,也沒(méi)有驚擾我的一枕春夢(mèng)。多少年來(lái),每次發(fā)現(xiàn)她...
    靜闌文學(xué)閱讀 320評(píng)論 0 0
  • https://mp.weixin.qq.com/s/Tky1GAXp6-mBEcZbh-0IDw
    老李耕田閱讀 213評(píng)論 0 0

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