Vue的虚拟DOM和diff算法你了解吗

 更新时间:2022年02月10日 15:52:41   作者:旺仔流奶  
这篇文章主要为大家详细介绍了Vue的虚拟DOM和diff算法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助

在vue 中

数据改变 -> 虚拟DOM(计算变更)-> 操作DOM -> 视图更新

虚拟DOM: js执行速度比较快

什么是虚拟DOM?

用JS模拟DOM结构

为什么需要虚拟DOM?

vue中 数据驱动视图,需要用高效方法来控制DOM操作的次数

diff算法: 虚拟DOM的核心

patch函数

两个使用场景:

首次渲染时,判断第一个参数是否是一个真实dom元素,是的话就创建空vnode,并且关联一个DOM元素,然后比较patch函数传入的第一个参数和第二个参数是否是同一个vnode,如果是同一个vnode,那么就直接patchVnode做更新,如果是不同的vnode,那么就创建新的DOM元素,插入,并且把老的DOM元素删除。

patchVnode函数:

updateChildren函数:

DOM Diff

对比两个虚拟节点,找出他们的差异,然后对应到真实DOM节点 去打补丁(patch)的过程

目的:以最小的代价来去修改DOM

虚拟节点:将真实DOM用一个对象来表达出来。

defineProperty Proxy的区别:

本质上有不同,所以使用上有所不同。

defineProperty 本质是给对象增加属性用的,所以在修改数组长度,用索引设置数组的值,数组的push(),pop() 是无法触发

defineProperty 中的set 的。所以Vue2中是使用自己定义的一些数组方法来实现的。

Proxy 没有这个缺点。

Vue2 中不使用Proxy的原因是因为proxy是属于ES6,当时考虑的是兼容性的问题。

Reflect 反射 内置对象 方法集合的容器

Reflect 的好处:

之前的好多方法都挂在Object上,就很混乱。

未来很多方法都会逐渐放在Reflect上,成为内置方法的容器,统一管理各种方法。

Reflect.has(obj,'a') // 函数式编程。

对比 'a' in obj

Object中的方法有些会直接抛出异常,需要包裹try catch

而Reflect中的方法一般都有返回值,失败后会合理返回。

Proxy 中handler中的方法 和Reflect中的方法是一一对应的。

Reflect 是ES6中全局的内置对象。直接保存的静态方法,不需要实例化,可以直接使用。

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!    

相关文章

  • 在Vue中使用deep深度选择器修改element UI组件的样式

    在Vue中使用deep深度选择器修改element UI组件的样式

    这篇文章主要介绍了在Vue中使用deep深度选择器修改element UI组件的样式,本文分为两种方法给大家介绍,在这小编比较推荐使用第二种使用 deep 深度选择器,感兴趣的朋友跟随小编一起看看吧
    2022-12-12
  • Vue实现PC端分辨率自适应的示例代码

    Vue实现PC端分辨率自适应的示例代码

    本文主要介绍了Vue实现PC端分辨率自适应的示例代码,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • vue @vuelidate父子组件绑定注意事项

    vue @vuelidate父子组件绑定注意事项

    Vue@vuelidate父子组件验证时,不能直接绑定,需在子组件验证方法内部进行绑定,以避免父组件验证时包含子组件的验证
    2025-02-02
  • 前端框架之封装Vue第三方组件三个技巧

    前端框架之封装Vue第三方组件三个技巧

    这篇文章主要为大家介绍了前端框架封装Vue第三方组件的三个技巧示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • Vue组件BootPage实现简单的分页功能

    Vue组件BootPage实现简单的分页功能

    这篇文章主要为大家详细介绍了Vue小组件BootPage实现简单的分页功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • Vue结合Video.js播放m3u8视频流的方法示例

    Vue结合Video.js播放m3u8视频流的方法示例

    本篇文章主要介绍了Vue+Video.js播放m3u8视频流的方法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • 在vue使用echarts报错:invalid dom问题

    在vue使用echarts报错:invalid dom问题

    这篇文章主要介绍了在vue使用echarts报错:invalid dom问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • Vue列表页渲染优化详解

    Vue列表页渲染优化详解

    这篇文章主要为大家详细介绍了Vue列表页渲染优化的操作,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • vue递归组件实战之简单树形控件实例代码

    vue递归组件实战之简单树形控件实例代码

    这篇文章主要介绍了vue递归组件实战之简单树形控件的实例代码,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-08-08
  • vue el-table 动态添加行与删除行的实现

    vue el-table 动态添加行与删除行的实现

    这篇文章主要介绍了vue el-table 动态添加行与删除行的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07

最新评论