构建一个虚拟DOM并转换为真实DOM
關(guān)于真實DOM與虛擬DOM
1.在學(xué)習(xí)虛擬DOM之前,讓我們先來了解一下真實的DOM結(jié)構(gòu),這里不得不提的是關(guān)于瀏覽器渲染方面的知識。
? ? ? ? ? ? ? ? ? ? ??
?
2.為什么要使用虛擬DOM?
3.構(gòu)建一個虛擬DOM
一個ELement對象相當(dāng)于虛擬DOM上一個節(jié)點,參數(shù)如下:tagName:元素名稱props : 元素屬性,例如:class title等(以鍵值對方式存在)children : 該節(jié)點下的子節(jié)點數(shù)組? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
現(xiàn)在我們來定義一個虛擬DOM樹
? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
4.將虛擬DOM映射為真實DOM
? ? 為Element對象添加原型方法,render函數(shù)。函數(shù)作用:將虛擬DOM樹映射為真實DOM。這里使用了深度優(yōu)先DFS算法進(jìn)行節(jié)點的遍歷。
5.最后一步,將創(chuàng)建的真實DOM添加入文檔流中。
? ? ? ? ? ? ? ? ? ??
6.顯示效果
? ? ? ? ? ? ? ? ? ??
總結(jié):虛擬DOM在框架如VUE,React中的運(yùn)用,保證了性能下限,虛擬DOM是JS對象的抽象化,具有更好的跨平臺性,無需手動對DOM進(jìn)行操作。對于框架而言,是提供一個普適化的解決方案。使用虛擬DOM在保證代碼的可維護(hù)性下,提供一個不錯的性能。
對于一些對性能要求極高的平臺,如VScode,采用手動優(yōu)化DOM的操作進(jìn)行極端的性能優(yōu)化
原文鏈接:https://blog.csdn.net/qq_38918017/article/details/108321192
總結(jié)
以上是生活随笔為你收集整理的构建一个虚拟DOM并转换为真实DOM的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 意外医疗保险范围
- 下一篇: 华为底部虚拟导航栏挡住布局