为什么虚拟dom会提高性能?

虚拟DOM通过缓存机制和diff算法减少了不必要的DOM操作,提升了Web应用性能。它抽象了渲染过程,允许在多种平台上使用,如浏览器、小程序和原生移动应用。Vue.js利用虚拟DOM进行模板编译和更新,通过watcher对象实现视图同步。
摘要由CSDN通过智能技术生成

概念:虚拟dom相当于在js和真实的dom中间加了一个缓存,利用dom 的diff算法避免了没有必要的dom操作,从而提高了性能。

为什么一定要用虚拟dom?
        你用传统的原生api或jquery去操作dom时,浏览器会从构建dom树开始,从头到尾执行一遍流程。

真实dom的执行流程:用js对象表示真实的dom结构,当状态发生变化的时候,会重新创建一个虚拟dom树的结构,然后用新的树和旧的树进行比较,记录两颗树的差异,把所记录的差异应用到所构建的真实的dom树上,视图就更新了。

概括来说:模板——>渲染函数——>虚拟dom树——>真实dom。

举例说明渲染过程?
        当你一次需要更新10个dom节点,浏览器没有这么智能,它会在接收到第一个dom节点之后,并不知道后续还有九次更新的操作,因此会马上执行流程,因此会马上执行流程,最终执行10次流程。

而通过vnode,同样更新10个dom节点,虚拟dom不会立即进行操作,而是将这10次更新的diff内容保存到本地的一个js对象上,最终将这个js对象一次性的attach到dom树上,避免了大量的无谓的操作。

很多人认为虚拟dom最大的优势是diff算法,减少了javascript操作真实dom的带来的性能的消耗。虽然这是虚拟dom带来的优势,但是这不是全部的优势,虚拟dom最大的优势在于抽象了原本的渲染过程,实现了跨平台的能力,而不仅仅局限于浏览器的dom,可以是安卓和ios的原生组件,可以是近期很火热的小程序,也可以是各种GUI。

vue的虚拟dom是怎样的执行流程?
        vue.js是通过编译将模板渲染成函数,执行函数可以得到一个虚拟节点。在对dom进行操作的时候,会触发对应的dep中的watcher对象。wacther对象会调用对应的update来修改视图。

虚拟dom实现的原理三部分?
        用javascript对象模拟真实的dom树,对dom进行抽象。

        diff算法——比较两个虚拟dom树的差异

        pach算法——将两个虚拟dom对象的差异更新到真实的dom树。(pathc也叫patching,算法,这个过程是对比新旧虚拟节点之间有哪些不同,然后根据对比结果,找出需要更新的节点进行更新。)

虚拟dom的好处?
        降低浏览器的性能的消耗:javascript的运行速度远大于dom操作的执行速度,因此,运行patching算法来计算出真正的需要更新的节点,最大限度地减少了dom操作。

减少回流和重绘:通过diff算法,减少回流和重塑,通过diff算法优化遍历,对真实的dom进行打补丁式的新增、修改、删除、实现局部更新,减少回流和重绘等操作。用diff算法,减少了回流和重绘。

跨平台:虚拟dom本质上是js对象,相比之下虚拟dom,可以进行更方便的跨平台操作,例如浏览器的渲染、node、weex开发等。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
虚拟DOM(Virtual DOM)是一种在内存中用 JavaScript 对象表示网页的 DOM 结构的技术。通过使用虚拟DOM,可以在保持页面功能不变的同时,提高网页性能的主要原因如下: 1. 批量更新:虚拟DOM能够将多个DOM操作批量处理,减少了直接操作实际DOM的次数。通过比较虚拟DOM树和实际DOM树的差异,只对需要更新的部分进行实际DOM操作,从而减少了浏览器的重绘和回流次数。 2. 减少重绘和回流:虚拟DOM可以通过比较更新前后的虚拟DOM树差异,只更新需要变化的部分。这种优化方式可以减少浏览器对页面进行重绘和回流的次数,从而提高网页性能。 3. 提高渲染效率:虚拟DOM可以在内存中进行操作,而不是直接操作实际DOM。在虚拟DOM中进行各种计算和操作要比直接在实际DOM中进行快得多。这样可以提高页面的渲染效率,减少用户在页面上的等待时间。 4. 跨平台支持:虚拟DOM是对实际DOM的抽象表示,在不同平台上运行的应用程序可以共享相同的虚拟DOM操作逻辑。这种跨平台支持使得开发者能够更轻松地开发和维护多平台的应用程序。 需要注意的是,虚拟DOM并不一定总是能够提高网页性能。在某些情况下,虚拟DOM的额外计算和比较操作可能带来一定的性能开销。因此,在实际应用中,仍然需要根据具体情况综合考虑使用虚拟DOM的优缺点,并进行性能测试和优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值