Vue.js中的虚拟DOM

一.节点和状态

在我们平常对DOM操作的时候,之前在vue没有诞生之前,以命令式的方式对DOM进行操作,页面上的每一个元素都可以看做成一个节点状态。

二.剔除和渲染

框架都有自己渲染的方式,假设一个页面的状态,随着Ajax请求的放松,状态发生改变,有以下的两种方式供你选择:

1.将前面所有的节点都清空,重写渲染新的节点。

2.只更新更改的部分。

从性能上看,只更新更改的部分,也许是最优解,因为这样大大减少了计算机的缓存,每一个节点都需要去通过监听。

三.什么是虚拟节点树

刚才讲了传统的操作页面的方式,通过命令式的一步步操作,虚拟DOM通过状态生成一个虚拟节点树,虚拟节点树其实是由组件树建立起来的整个虚拟节点(vnode)树。

四.渲染的流程

1.我们使用通过模板 来描述状态DOM之间的关系,

模板<---------------->DOM

2.通过编译模板将模板转换成渲染函数

模版------------------------>编译------------------->渲染函数(render)

3.执行渲染函数

渲染函数(render)----------------------->执行------------------->虚拟节点树(vnode)

4.虚拟节点树使用

虚拟节点树------------->使用------------------------>渲染页面

如果直接使用的话会覆盖旧的节点,

这个时候进行会存在对比

oldVnode和vnode进行对比,vnode是一JavaScript一个普通的对象。

通过patch算法得到一个新的虚拟节点树,来进行更新,达到最佳优化。

相关推荐
芯智工坊5 小时前
每周一个开源项目 #4:ChatGPT-Next-Web 增强版
前端·chatgpt·开源
左右用AI5 小时前
每周1亿次下载的axios被投毒了,但是源码里没有一行恶意代码!
前端·后端
英俊潇洒美少年5 小时前
前端模块化 AMD、CMD、CommonJS、ESM的差异对比
前端
攀登的牵牛花5 小时前
Claude Code 泄露事件复盘:前端发布流程哪里最容易翻车
前端·github·claude
D_C_tyu5 小时前
vue3 + vue3-print-nb 插件实现打印功能
前端·javascript·vue.js
paul_chen215 小时前
Vite + Vue SPA 在子路径部署(内外网访问+Nginx 反向代理)
前端·vue.js·nginx
星如雨グッ!(๑•̀ㅂ•́)و✧5 小时前
Reactor背压
java·服务器·前端
笑笑先生5 小时前
从接口搬运工到研发控制平面,BFF 到底在解决什么?
前端·架构·node.js
霪霖笙箫6 小时前
「JS全栈AI Agent学习」二、反思、工具使用、规划——让 Agent 从"执行者"变成"自主完成者"
前端·agent·ai编程
前端缘梦6 小时前
Next.js全栈项目部署全流程|从0到1解决数据库、WebSocket、图片上传所有坑
前端·全栈·next.js