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算法得到一个新的虚拟节点树,来进行更新,达到最佳优化。

相关推荐
猩猩程序员12 小时前
Vercel 推出 Agent 框架 Eve:让 AI Agent 像写 Web 应用一样简单
前端
小林ixn12 小时前
别再背八股了!从 5 个真实场景彻底搞懂 JavaScript 的 this
javascript
爱读源码的大都督12 小时前
Claude Code源码分析(三):为什么系统提示词中需要有tools呢?
前端·人工智能·后端
爱勇宝12 小时前
Claude Code 被曝暗藏“隐形检测”代码:封代理不是最可怕的,可怕的是你根本不知道它在干什么
前端·后端·程序员
小牛不牛的程序员12 小时前
我用 Claude Code 半天撸完了一个完整网站,AI 编程到底提升了多少效率?
前端
东风破_12 小时前
JavaScript 面试常考的字符串算法:从反转字符串到回文判断
前端·javascript
巴勒个啦12 小时前
D3.js 入门实战:用力导向图可视化项目依赖关系
javascript
ITOM运维行者13 小时前
从零搭建企业级服务器监控体系:踩坑实录与架构设计
前端·后端
monologues13 小时前
深入 Vue 3 源码:响应式系统的精妙设计与编译优化
前端
hunterandroid13 小时前
Paging 3 分页:从手动分页到声明式加载
前端