vue的diff算法
简单来说,就是vue的diff算法在对新老虚拟daom进行对比时,是从节点的两侧向中间对比;如果节点的key值与元素类型相同,属性值不同,就会认为是不同节点,就会删除重建
react的diff算法
react的diff算法在对新老虚拟dom进行对比是,是从节点左侧开始对比,就好比将新老虚拟dom放入两个栈中,一对多依次对比;如果节点的key值与元素类型相同,属性值不同,react会认为是同类型节点,只是修改节点属性
两种diff算法的相同点
都只进行同级比较,忽略了跨级操作;常见的现象就是对数组或者对象中的深层元素进行修改时,视图层监测不到其变化,故不会对dom进行更新,需调用一些特质方法来告诉视图层需要更新dom