1.当数据发生变化时,vue是怎么更新节点的?
渲染真实dom的开销很大,比如我们修改了某个数据,如果直接渲染到真实dom会引起整个dom树的重绘和重排,有没有可能我们只更新我们修改的那一小块dom而不更新整个dom呢?diff算法可以帮助我们。
我们根据真实dom生成一个虚拟dom,当虚拟dom某个节点的数据改变后会生成一个新的Vnode,然后Vnode和oldVnode做对比,发现有不一样的地方就直接修改在真实的DOM上,然后使oldVnode的值为Vnode。
diff的过程就是调用名为patch的函数,比较新旧节点,一边比较一边给真实的Dom打补丁。
2. virtual DOM和真实DOM的区别?
virtual DOM是将真实的DOM的数据抽取出来,以对象的形式模拟树形结构。比如dom是这样的:
123
var Vnode = {
tag: ‘div’,
children: [
{ tag: ‘p’, text: ‘123’ }
]
};
(温馨提示:VNode和oldVNode都是对象,一定要记住)
3. diff的比较方式?
在采取diff算法比较新旧节点的时候,比较只会在同层级进行, 不会跨层级比较。
具体请参考大佬文章:https://www.cnblogs.com/wind-lanyan/p/9061684.html
https://github.com/aooy/blog/issues/2