這篇文章帶大家聊聊vue中的虛擬DOM,介紹一下什麼是虛擬dom、引入vdom的好處、vue 為什麼採用 vdom,希望對大家有幫助!
現有框架幾乎都引入了虛擬DOM 來對真實DOM 進行抽象,也就是現在大家所熟知的VNode 和VDOM,那麼為什麼需要引⼊虛擬DOM 呢?本文圍繞著這個疑問來解答即可! (學習影片分享:vuejs入門教學)
虛擬dom顧名思義就是虛擬的dom對象,它本身就是⼀個JavaScript 對象,只不過它是透過不同的屬性去描述⼀個視圖結構。
1. 將真實元素節點抽象化為VNode,有效減少直接操作dom 次數,從而提高程式效能
2. 方便實作跨平台
、原生應用程式(
Weex/React Native)、小程式(
mpvue/uni-app)等、渲染到WebGL 中等等。
補充:vue 為什麼採用 vdom?
Virtual DOM 在效能方面的考量只是一方面。
Virtual DOM 哪個的效能更好還真不是一個容易下定論的問題。
Vue 之所以引入了
Virtual DOM,更重要的原因是為了解耦
HTML依賴,這帶來兩個非常重要的好處是:
解析器進行模版解析,可以進行更多的
AOT 工作提高運行時效率:透過模版
AOT 編譯,
Vue 的運行體積可以進一步壓縮,運行時效率可以進一步提升;
以外的平台,實作
SSR、同構渲染這些高階特性,
Weex等框架應用的就是這項特性。
綜上,3. vdom如何生成,又如何成為真實dom在vue中我們常常會為元件寫模板- template, 這個模板會被編譯器- compiler編譯為渲染函數,接下來的掛載(mount)過程中會呼叫render函數,傳回的物件就是虛擬dom。但它們還不是真正的dom,所以會在後續的patch過程中進⼀步轉化為dom。 4. 在後續的diff中的作用掛載程序結束後,vue程式進入更新流程。如果某些響應式資料發生變化,將會引起元件重新render,此時就會產生新的vdom,和上一次的渲染結果diff就能得到變化的地方,從而轉換為最小量的dom操作,高效更新視圖。 原始碼直達vnode定義:https://github1s.com/vuejs/core/blob/HEAD/packages/runtime-core/src/vnode.ts#L127-L128Virtual DOM
在效能上的效益並不是最主要的,更重要的是它使得
Vue具備了現代框架應有的高階特性。
[建立vnode]:
createElementBlock:https://github1s.com/vuejs/core/blob/HEAD/packages/runtime-core/src/vnode.ts #L291-L292createVnode:https://github1s.com/vuejs/core/blob/HEAD/packages/runtime-core/src/vnode.ts#L486-L487首次呼叫時刻:https://github1s.com/vuejs/core/blob/HEAD/packages/runtime-core/src/apiCreateApp.ts#L283-L284
mount:https:// github1s.com/vuejs/core/blob/HEAD/packages/runtime-core/src/renderer.ts#L1171-L1172
(學習影片分享:web前端)
以上是聊聊什麼是虛擬dom? vue為什麼要採用vdom?的詳細內容。更多資訊請關注PHP中文網其他相關文章!