美文网首页
diff算法

diff算法

作者: 你喜欢吃青椒吗_c744 | 来源:发表于2019-08-19 17:02 被阅读0次

原文:详解vue的diff算法

当数据发生变化时,vue是怎么更新节点的?

要知道渲染真实DOM的开销是很大的,比如有时候我们修改了某个数据,如果直接渲染到真实dom上会引起整个dom树的重绘和重排,有没有可能我们只更新我们修改的那一小块dom而不要更新整个dom呢?diff算法能够帮助我们。

我们先根据真实DOM生成一颗virtual DOM,当virtual DOM某个节点的数据改变后会生成一个新的Vnode,然后Vnode和oldVnode作对比,发现有不一样的地方就直接修改在真实的DOM上,然后使oldVnode的值为Vnode。

diff的过程就是调用名为patch的函数,比较新旧节点,一边比较一边给真实的DOM打补丁。

virtual DOM和真实DOM的区别?

virtual DOM是将真实的DOM的数据抽取出来,以对象的形式模拟树形结构。比如dom是这样的:

<div>
    <p>123</p>
</div>

//对应的virtual DOM(伪代码):
var Vnode = {
    tag: 'div',
    children: [
        { tag: 'p', text: '123' }
    ]
};

diff的比较方式

在采取diff算法比较新旧节点的时候,比较只会在同层级进行, 不会跨层级比较

image.png
比较后会出现四种情况:
  • 此节点是否被移除 -> 添加新的节点
  • 属性是否被改变 -> 旧属性改为新属性
  • 文本内容被改变-> 旧内容改为新内容
  • 节点要被整个替换 -> 结构完全不相同 移除整个替换

diff流程图

当数据发生改变时,set方法会让调用Dep.notify通知所有订阅者Watcher,订阅者就会调用patch给真实的DOM打补丁,更新相应的视图。


image.png

相关文章

网友评论

      本文标题:diff算法

      本文链接:https://www.haomeiwen.com/subject/yulesctx.html