【vue】diff 算法详解

这篇具有很好参考价值的文章主要介绍了【vue】diff 算法详解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、diff算法是什么

diff算法是一种通过同层的树节点进行比较的高效算法

        diff算法的目的就是找出新旧不同虚拟DOM之间的差异,使最小化的更新视图,所以 diff 算法本质上就是比较两个js对象的差异

特点

        1. 比较只会在同层级进行,不会跨层级比较

        2. 在diff比较的构成中,循环从两边向中间比较

应用场景

        diff算法在很多场景下都有应用,在vue中,用作于虚拟DOM渲染成真是DOM的新旧VNode节点比较

diff算法,前端,vue,前端

二、比较方式

diff整体策略为:深度优先,同层比较

        1. 比较只会在同层级进行,不会跨层级比较

        2. 比较的过程中,循环从两边向中间收拢

三、原理分析

diff算法,前端,vue,前端

数据改变 ----触发--> setter---触发--->Dep.notify ---通知订阅者---> patch(oldvnode, newvnode)

之后判断新旧两个节点是否为同类标签,如果不是同类标签就直接替换;如果是同类标签的话,进一步执行patchVnode()方法,在这个方法内部,也是需要先判断一下新旧虚拟节点是否相同,如果相等,就直接return;如果不相等就需要分情况来比对,比对的原则就是以新虚拟节点的结果为准,分为以下几种情况:

  1. oldvnode和newvnode都有文本节点---执行--->用新的文本节点替换旧文本节点
  2. oldvnode没有子节点,newvnode有子节点---执行--->添加新的子节点
  3. oldvnode有子节点,newvnode没有子节点---执行--->删除旧的子节点
  4. oldvnode和newvnode都有子节点---执行--->updateChildren()方法

updateChildren

同级比对 --- 减少比对次数,可以最大化的提高比对性能

diff算法,前端,vue,前端

首尾指针法

        ①依次比对,当比较成功后退出当前比较

        ②渲染结构以newVnode为准

        ③每次比较成功之后start点和end点向中间靠拢

        ④当新旧节点中有一个start点跑到end点右侧时终止比较

        ⑤如果都匹配不到,则旧虚拟DOM key只去比对新虚拟DOM的key值,如果key相同则复用,并移动到新虚拟DOM的位置

比对顺序

        首先,旧虚拟节点的start和新虚拟节点的start做比对,如果没有比对成功,就用旧虚拟节点的start和新虚拟节点的end做比对

diff算法,前端,vue,前端

        如果依旧没有比对成功,就用旧虚拟节点的end和新虚拟节点的start做比对,如果依旧没有比对成功,旧虚拟节点的end会和新虚拟节点的end做比对

diff算法,前端,vue,前端

        比对原则就是依照以上顺序依次比较

        当比对成功,就退出当前比对,渲染结果会以新虚拟节点的结果为准

        每次比对成功后,比对成功的start会向右侧移动,end会向左侧移动。在移动的过程中,当start点跑到end点右侧的时候就终止比较

比对实例

diff算法,前端,vue,前端

diff算法,前端,vue,前端

diff算法,前端,vue,前端

diff算法,前端,vue,前端文章来源地址https://www.toymoban.com/news/detail-782585.html

到了这里,关于【vue】diff 算法详解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【源码系列#06】Vue3 Diff算法

    专栏分享:vue2源码专栏,vue3源码专栏,vue router源码专栏,玩具项目专栏,硬核💪推荐🙌 欢迎各位ITer关注点赞收藏 🌸🌸🌸 Vue2 Diff算法可以参考此篇文章 【Vue2.x源码系列08】Diff算法原理 两个不同虚拟节点不需要进行比较,直接移除老节点,将新的虚拟节点渲染成真实D

    2024年01月17日
    浏览(27)
  • vue diff 前后缀+最长递增子序列算法

    如上图所示,新旧 children 拥有相同的前缀节点和后缀节点 对于前缀节点,我们可以建立一个索引,指向新旧 children 中的第一个节点,并逐步向后遍历,直到遇到两个拥有不同 key 值的节点为止 对于相同的后缀节点,由于新旧 children 中节点的数量可能不同,所以我们需要两个

    2024年02月13日
    浏览(27)
  • vue diff算法与虚拟dom知识整理(6) 感受diff算法 (不要神话虚拟dom更不要做完美主义)

    我们还是打开之前的案例 然后 将src下的index.js代码修改如下 首先 我们写入节点的方法叫 patch 我们来查一下这个单纯的意思 其实 他不是一个暴力装卸的方法 而是 修补的一个概念 因为 我们需要一个触发事件的工具 所以 我们在www文件夹下的index.html中加一个id为btn的按钮 参考

    2024年02月04日
    浏览(25)
  • vue2和vue3之间diff算法的差异

    1.Virtual DOM的优化 Vue 2 中的 diff 算法针对整个 Virtual DOM 树进行了完整的比较,导致在大型应用中可能存在性能问题。 Vue 3 中通过静态分析和标记,将组件标记为静态、动态或稳定,从而避免不必要的 Virtual DOM 比较,提高了渲染性能。 2.动态指令的优化 Vue 2 中动态指令的 di

    2024年02月04日
    浏览(29)
  • 【Vue2.x源码系列08】Diff算法原理

    DOM是很慢的,其元素非常庞大,当我们频繁的去做 DOM更新,会产生一定的性能问题,我们可以直观感受一下 div元素包含的海量属性 在Javascript对象中, 虚拟DOM 表现为一个 Object对象(以VNode 节点作为基础的树)。并且最少包含标签名 tag 、属性 attrs 和子元素对象 children 三个

    2024年02月05日
    浏览(31)
  • vue2和vue3diff算法的区别?

    vue2和vue3diff算法的区别 diff 算法是一种通过同层的树节点进行比较的高效算法 其有两个特点: 比较只会在同层级进行, 不会跨层级比较 在diff比较的过程中,循环从两边向中间比较 diff 算法在很多场景下都有应用,在 vue 中,作用于虚拟 dom 渲染成真实 dom 的新旧 VNode 节点比较

    2024年02月11日
    浏览(28)
  • Vue3 Diff算法之最长递增子序列,学不会来砍我!

    专栏分享:vue2源码专栏,vue3源码专栏,vue router源码专栏,玩具项目专栏,硬核💪推荐🙌 欢迎各位ITer关注点赞收藏 🌸🌸🌸 Vue2 Diff算法可以参考 【Vue2.x源码系列08】Diff算法原理 Vue3 Diff算法可以参考 【Vue3.x源码系列06】Diff算法原理 在 上一章结尾乱序比对 算法中,可以看

    2024年01月19日
    浏览(27)
  • vue diff算法与虚拟dom知识整理(4) h函数虚拟节点嵌套

    那么 先补充上文有一个没强调的点 h函数 当你不需要属性时 其实是可以不传的 例如 我们打开案例 打开 src下的index.js 修改代码如下 声明标签为div 不需要任何标签属性 因此 我们就直接 告诉他div 然后后面一个参数直接跟里面的文本 程序也能识别 我们运行项目 可以看到 一切

    2024年02月02日
    浏览(41)
  • 面试被问到vue的diff算法原理,我不允许你回答不上来

    diff 算法是一种通过同层的树节点进行比较的高效算法 其有两个特点: 比较只会在同层级进行, 不会跨层级比较 在diff比较的过程中,循环从两边向中间比较 diff 算法在很多场景下都有应用,在 vue 中,作用于虚拟 dom 渲染成真实 dom 的新旧 VNode 节点比较 diff 整体策略为:深度

    2023年04月12日
    浏览(31)
  • vue-3:生命周期,computed,watch,filter,虚拟dom和diff算法

    生命周期 Vue生命周期的 主要阶段 :4个before, 4个ed,创建,装载,更新,销毁 记得说单词: 第一次执行前4个生命周期钩子函数, 模板在mounted时渲染完毕, 父子组件的生命周期顺序(父组件前三个,子组件前四个,父组件再第四个) computed:{} 计算属性(总价+-*/) // 对d

    2024年02月04日
    浏览(34)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包