一 ,vue2和vue3双向数据绑定原理的区别?
vue2的双向数据绑定是利用ES5的一个API Object.definePropert() 对数据进行劫持 结合 发布订阅模式的方式来实现的
vue3发生了改变,使用proxy替换 Object.definePropert,使用Proxy的优势;
二 ,根节点不同
vue3在组件中支持多个根节点
三 ,Composition API (组合api)
vue2和vue3最大的区别就是,vue3使用了Composition API (组合api)
在vue2中是使用的Options API,这种写法不方便我们的阅读和交流,逻辑过于分散。
四 ,vue2和vue3的diff算法
vue2 :
vue2 diff算法就是进行虚拟节点对比,并返回一个patch对象,用来存储两个节点不同的地方,最后用patch记录的消息去局部更新Dom。
vue2 diff算法会比较每一个vnode,而对于一些不参与更新的元素,进行比较是有点消耗性能的。
vue3:
vue3 diff算法在初始化的时候会给每个虚拟节点添加一个patchFlags,patchFlags就是优化的标识。
只会比较patchFlags发生变化的vnode,进行更新视图,对于没有变化的元素做静态标记,在渲染的时候直接复用。