返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue中对虚拟dom的理解知识点总结
  • 815
分享到

vue中对虚拟dom的理解知识点总结

2024-04-02 19:04:59 815人浏览 独家记忆
摘要

本质是一个普通的js对象,用于描述视图界面结构的, 在mouted的回调中,可以输出_vnode,  通过图可以知道,_vnode中有以下几个主要的属性: t

本质是一个普通的js对象,用于描述视图界面结构的,

在mouted的回调中,可以输出_vnode

 通过图可以知道,_vnode中有以下几个主要的属性:

  • tag:组件的标签名,
  • data: 组件的属性,
  • children: 组件的子标签
  • parent: 父级元素

render函数:

作用:创建虚拟dom,

 每个组件都有虚拟dom,并且虚拟dom都是由render函数创建的;

使用虚拟dom树的目的:提高渲染效率

Vue中,当渲染视图时候会调用render函数。这种渲染不仅发生在组件创建时候,还会发生在视图所依赖的数据更新时;

由于真实dom的创建、更新。插入等操作带来大量的性能消耗,从而降低渲染效率,所以使用虚拟dom树来代替真实dom。

虚拟dom如何转换成真实dom

组件实例首次渲染:生成虚拟dom树,根据虚拟dom树创建真实dom,并把真实dom挂载到页面合适位置,此时每个虚拟dom对应一个真实dom;

备注:在虚拟dom中,都由elm属性,就是真实dom,也就是说,生成的虚拟dom同时,都创出了真实dom,也就是说,第一次的渲染,vue比单纯创建dom元素要效率低,vue的高效体现在响应式数据变化的虚拟dom对比

组件依赖的数据收到响应式数据的影响时:重新调用render函数创建虚拟dom树,用新旧虚拟dom树比较,vue会找到最小更新量,然后更新必要的虚拟dom节点,最后修改对应的真实dom。这样就保证了对真实dom达到最小的变动。

真实dom的属性的数量要远远大于虚拟dom属性,并且任意的对真实dom的添加删除都会导致重排重绘问题。这非常消耗性能。

备注:真实dom和普通对象创建的耗时比较

 可以看出,dom对象创建是普通对象耗时20多倍。

模板和虚拟dom的关系

vue框架中有一个compile模板,它主要负责将模板转换成为render函数,而render函数调用后将得到虚拟dom

编译过程分为两步

1.将模板字符串转换成为AST(抽象语法树,用js树形结构描述原始代码,下图通过AST在线转换可以看出结构。

2.将AST转换成为render函数

运行时编译和模板预编译

当采用传统引入方式,则编译发生的时间为组件第一次加载时,成为运行时编译

如果在vue-cli的默认情况下,编译发生在打包时(npm run build / serve),成为模板预编译。

编译是一个极其消耗性能的操作,预编译可以有效提高运行时的性能,而且由于运行的时候已经不需要编译,vue-cli在打包时会排除掉vue中的compile模块,以减少打包体积。模板的存在,仅仅是为了让开发人员更方便的写代码。

知识点扩展:

虚拟 dom 的作用

现在主流的框架都是声明式操作 dom 的框架。我们只需要描述状态与 dom 之间的映射关系即可,状态到视图(真实的 dom)的转换,框架会帮我们做。

最粗暴的做法是将状态渲染成视图,每次更新状态,都重新更新整个视图。

这种做法的性能可想而知。比较好的想法是:状态改变,只更新与状态相关的 dom 节点。虚拟 dom 只是实现这个想法的其中一种方法而已。

具体做法:

状态 -> 真实 dom(最初)

状态 -> 虚拟 dom -> 真实 dom(使用虚拟 dom)

状态改变,重新生成一份虚拟 dom,将上一份和这一份虚拟 dom 进行对比,找出需要更新的部分,更新真实 dom。

vue 中的虚拟 dom

真实的 dom 是由 节点(Node)组成,虚拟 dom 则是由虚拟节点(vNode)组成。

虚拟 dom 在 vue 中主要做两件事:

提供与真实节点(Node)对应的虚拟节点(vNode)

将新的虚拟节点与旧的虚拟节点进行对比,找出需要差异,然后更新视图

到此这篇关于vue中对虚拟dom的理解知识点总结的文章就介绍到这了,更多相关vue中对虚拟dom的理解内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: vue中对虚拟dom的理解知识点总结

本文链接: https://lsjlt.com/news/128637.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • vue中对虚拟dom的理解知识点总结
    本质是一个普通的js对象,用于描述视图界面结构的, 在mouted的回调中,可以输出_vnode,  通过图可以知道,_vnode中有以下几个主要的属性: t...
    99+
    2024-04-02
  • vue中的虚拟dom知识点总结
    目录一、简介二、为什么VUE引入了虚拟DOM?三、vnode1.vnode的类型四、虚拟dom的核心——patch1.patch的过程新增节点删除节点更新节点...
    99+
    2024-04-02
  • 总结DOM的知识点
    这篇文章主要介绍“总结DOM的知识点”,在日常操作中,相信很多人在总结DOM的知识点问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”总结DOM的知识点”的疑惑有所帮助!接下来,...
    99+
    2024-04-02
  • vue中的虚拟dom知识点有哪些
    本文小编为大家详细介绍“vue中的虚拟dom知识点有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue中的虚拟dom知识点有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、简介虚拟dom是随着时代发...
    99+
    2023-06-30
  • java虚拟机中栈的运行知识点总结
    运行原理 1、不同线程中所包含的栈帧是不允许存在相互引用的。 2、如果当前方法调用了其他方法,方法返回之际,当前栈帧会传回此方法的执行结果给当前一个栈针,并且虚拟机会丢弃当前栈帧,使...
    99+
    2024-04-02
  • vue中虚拟DOM与Diff算法知识精讲
    目录前言虚拟DOM(Virtual DOM):什么是虚拟DOM为什么要使用虚拟DOM:虚拟dom库diff算法snabbdom的核心init函数h函数patch函数(核心)diff算...
    99+
    2024-04-02
  • mysql中表的知识点总结
    这篇文章主要介绍“mysql中表的知识点总结”,在日常操作中,相信很多人在mysql中表的知识点总结问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql中表的知识点总结”...
    99+
    2024-04-02
  • Vue中使用计算属性的知识点总结
    计算属性 有些时候,我们在模板中放入了过多的逻辑,从而导致模板过重,且难以维护。例如: <div id="app"> {{ message.split('')....
    99+
    2024-04-02
  • java中基本注解的知识点总结
    1、java.lang.Override是一个标记类型注解,它被用作标注方法.他说明了该方法是继承了父类的方法,就是重写了父类中同名方法。 @Override public vo...
    99+
    2024-04-02
  • Java中类与对象的相关知识点总结
    目录一、面向过程与面向对象的理解二、类与对象的理解与认识三、类的成员1.字段/属性/成员变量2.对null的基本认识3.方法 (method)4.static 关键字四、封装1. p...
    99+
    2024-04-02
  • R语言中其它对象知识点总结
    其他对象 矩阵 二维向量 矩阵操作更类似于向量,而不是向量的向量或者向量列表 下标可以用用来引用元素,但并不反应矩阵的存储方式 矩阵没有一个确定的属性 数组 具有两个以上维度的向...
    99+
    2024-04-02
  • Python中的反射知识点总结
    通过字符串映射或修改程序运行时的状态、属性、方法, 可以通过下面这4中方法 ''' 使用getattr(object, name_str, default=None) 方...
    99+
    2024-04-02
  • Python中字典的知识点总结
    这篇文章主要讲解了“Python中字典的知识点总结”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python中字典的知识点总结”吧!一、概述字典的每个键值(key=>value)对用冒...
    99+
    2023-06-02
  • Java中的引用知识点总结
    本篇内容介绍了“Java中的引用知识点总结”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!强引用:默认情况下,对象采用的均为强引用(这个对象的...
    99+
    2023-06-05
  • Java中的异常和处理知识点总结
    这篇文章主要介绍“Java中的异常和处理知识点总结”,在日常操作中,相信很多人在Java中的异常和处理知识点总结问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java中的异常和处理知识点总结”的疑惑有所帮助!...
    99+
    2023-06-17
  • Python中set集合的知识点总结
    本篇内容介绍了“Python中set集合的知识点总结”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!集合的简介集合是一个无序、不重复的序列它的...
    99+
    2023-06-20
  • Java中的枚举相关知识点总结
    这篇文章主要讲解了“Java中的枚举相关知识点总结”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java中的枚举相关知识点总结”吧!Java中的枚举枚举通常是一组相关的常量集合,其他编程语言...
    99+
    2023-06-15
  • Rust中FFI编程知识点整理总结(推荐)
    目录Rust语言对FFI的支持libc-crate库cbindgen 工具的介绍和使用Rust指针1.Rust自带的指针类型:2. 原始指针3.智能指针Rust和C交互时的各种指针变...
    99+
    2024-04-02
  • 关于Python面向对象编程的知识点总结
    前言 如果你以前没有接触过面向对象的编程语言,那你可能需要先了解一些面向对象语言的一些基本特征,在头脑里头形成一个基本的面向对象的概念,这样有助于你更容易的学习Python的面向对象编程。 接下来我们就来了...
    99+
    2022-06-04
    知识点 面向对象 Python
  • python中Task封装协程的知识点总结
    说明 Task是Future的子类,Task是对协程的封装,我们把多个Task放在循环调度列表中,等待调度执行。 Task对象可以跟踪任务和状态。Future(Task是Futrue的子类)为我们提供了异步编程中最终...
    99+
    2022-06-02
    python Task 封装协程
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作