jeddygong / frontend-document

前端每日一练,大厂面试题目,涵盖前端所有知识点,每天进步一点点。HTML/CSS/Javascript/Nodejs/Typescript/ECMAScript/Vue/React/Webpack/小程序/网络/设计模式/数据结构/算法/安全/工程化/性能优化
https://jeddygong.github.io/frontend-document
MIT License
10 stars 4 forks source link

[Vue&React] [2021-01-06 更新] 对虚拟DOM的理解?虚拟DOM主要做了什么?虚拟DOM本身是什么? #6

Open jeddygong opened 3 years ago

jeddygong commented 3 years ago

什么是虚拟DOM

​ 从本质上讲,Virtual Dom是一个Javascript对象,通过对象的方式来表示DOM结构。将页面的状态抽象为JS对象的形式,配合不同的渲染工具,将使跨平台渲染成为可能。通过事物处理机制,将多次DOM修改的结果一次性的更新到页面上,从而有效的减少页面渲染的次数,减少修改DOM的重绘重排次数,提高渲染性能

​ Virtual Dom是对DOM的抽象,这个对象是更加轻量级的对DOM的描述。它涉及的最初目的,就是更好的跨平台,比如Nodejs就没有DOM,如果想实现SSR,那么加一个方式就是借助虚拟DOM,因为虚拟DOM本省是JS对象。在代码渲染到页面之前,vue或者react会把代码转换成一个对象(虚拟DOM)。以对象的形式来描述真实的DOM结构,最终渲染到页面。在每次数据发生变化前,虚拟DOM都会缓存一份,变化之时,现在的虚拟DOM会与缓存的虚拟DOM进行比较。

​ 在vue或者react内部封装了diff算法,通过这个就是无需手动操作DOM,一方面是因为手动操作DOM无法保证程序性能,多人协作的项目中如果review不严格,可能会有开发者写出性能较低的代码,另一方面更重要的是省略手动DOM的操作可以大大提高开发效率。

为什么要用到Virtual Dom

Virtual Dom 真的比真实Dom性能好吗?