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