vue3 diff源码梳理学习笔记

1、只比较同层

2、双端比较

3、判断流程

1、先判断是否是首次渲染;

2、vnode oldvnode 指向同一个对象?

3、oldvnode dom 关联到真实的元素上,依次更新dom上的属性,class style props events;

4、针对简单的文本节点 只需要更新文本内容

5、oldVnode 有子节点,vnode 没有子节点,直接删除oldVnode下的子节点

6、oldVnode 没有子节点,vnode有子节点,直接更新oldVnode下增加子节点

7、oldVnode vnode 都有子节点,则进行子节点对比。

4、patchVnode核心逻辑

1、先比较key,根据 头头,尾尾,头尾,尾头,四种比较类型;当key相同的时候,就进入比较;

相关推荐
猫头虎-前端技术3 分钟前
浏览器兼容性问题全解:CSS 前缀、Grid/Flex 布局兼容方案与跨浏览器调试技巧
前端·css·node.js·bootstrap·ecmascript·css3·媒体
阿珊和她的猫3 分钟前
探索 CSS 过渡:打造流畅网页交互体验
前端·css
元亓亓亓4 分钟前
JavaWeb--day1--HTML&CSS
前端·css·html
β添砖java4 分钟前
CSS的文本样式
前端·css
前端小趴菜054 分钟前
css - 滤镜
前端·css
祈祷苍天赐我java之术4 分钟前
理解 CSS 浮动技术
前端·css
索迪迈科技7 分钟前
Flex布局——详解
前端·html·css3·html5
咔咔一顿操作8 分钟前
【CSS 3D 实战】从零实现旋转立方体:理解 3D 空间的核心原理
前端·css·3d·css3
DONG91310 分钟前
深度解析CSS单位与媒体查询:构建现代化响应式布局的核心技术
前端·css·html·css3·媒体
一只小风华~16 分钟前
Vue: Class 与 Style 绑定
前端·javascript·vue.js·typescript·前端框架