iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >Javascript虚拟DOM详解
  • 673
分享到

Javascript虚拟DOM详解

2024-04-02 19:04:59 673人浏览 薄情痞子
摘要

目录什么是虚拟 dom?为什么需要虚拟dom?虚拟dom是如何转换为真实dom的?模板和虚拟dom的关系注入挂载完整流程总结 什么是虚拟 dom? 虚拟 dom 本质上就是一个普通的

什么是虚拟 dom?

虚拟 dom 本质上就是一个普通的js对象(mounted 中打印 this. _vnode 就是该对象内容),用于描述视图的界面结构

Vue中,每个组件都有一个render函数,每个render函数都会返回一个虚拟dom树,这也就意味着每个组件都对应一棵虚拟DOM树

在这里插入图片描述

vnode 是一个普通的 JS 对象,用于描述界面上应该有什么,比如:


var vnode = {
  tag: "h1",
  children: [
    { tag: undefined, text: "第一个vue应用:Hello World"}
  ]
}

上面的对象描述了:


有一个标签名为 h1 的节点,它有一个子节点,该子节点是一个文本,内容为「第一个vue应用:Hello World」

为什么需要虚拟dom?

在vue中,渲染视图会调用render函数,这种渲染不仅发生在组件创建时,同时发生在视图依赖的数据更新时。如果在渲染时,直接使用真实DOM,由于真实DOM的创建、更新、插入等操作会带来大量的性能损耗,从而就会极大的降低渲染效率。

因此,vue在渲染时,使用虚拟dom来替代真实dom,主要为解决渲染效率的问题。

对比创建js对象和真实 dom 对象效率:

在这里插入图片描述

结果:

在这里插入图片描述

创建一个真实的 dom 会伴随着创建许多的属性

在这里插入图片描述

虚拟dom是如何转换为真实dom的?

在一个组件实例首次被渲染时,它先生成虚拟dom树,然后根据虚拟dom树创建真实dom,并把真实dom挂载到页面中合适的位置,此时,每个虚拟dom便会对应一个真实的dom。如果页面只会刷新一次,后续不会有数据更新等问题的情况下,用虚拟 dom 的方式是比直接显示真实 dom 效率低的。

如果一个组件受响应式数据变化的影响,需要重新渲染时,它仍然会重新调用render函数,创建出一个新的虚拟dom树,用新树和旧树对比,通过对比,找出差异,然后仅更新差异部分的虚拟dom节点,最后,这些更新过的虚拟节点,会去修改它们对应的真实dom

这样一来,就保证了对真实dom达到最小的改动。

在这里插入图片描述

模板和虚拟dom的关系

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

编译的过程分两步:

1.将模板字符串转换成为AST(抽象语法树:用js树形结构来描述我们原始的代码;在线工具https://astexplorer.net/)

2.将AST转换为render函数

vue 模板并不是真实的 DOM,它会被编译为虚拟 DOM


<div id="app">
  <h1>第一个vue应用:{{title}}</h1>
  <p>作者:{{author}}</p>
</div>

上面的模板会被编译为类似下面结构的虚拟 DOM


{
  tag: "div",
  children: [
    { tag: "h1", children: [ { text: "第一个vue应用:Hello World" } ] },
    { tag: "p", children: [ { text: "作者:袁" } ] }
  ]
}

如果使用传统的引入方式(script src="...vue.js"),则编译时间发生在组件第一次加载时,这称之为运行时编译。

如果是在vue-cli的默认配置下,编译发生在打包时(npm run build),打包之后就没有模板只有 render 函数了,这称之为模板预编译。

编译是一个极其耗费性能的操作,预编译可以有效的提高运行时的性能,而且,由于运行的时候已不需要编译,vue-cli在打包时会排除掉vue中的compile模块,以减少打包体积

打包时是否需要包含 compile 模块,是通过 vue.config.js 中的 runtimeCompiler: true 来控制的,默认 false,不包含。不建议更改该配置

模板的存在,仅仅是为了让开发人员更加方便的书写界面代码

vue最终运行的时候,最终需要的是render函数,而不是模板,因此,模板中的各种语法,在虚拟dom中都是不存在的,它们都会变成虚拟dom的配置

在 vue-cli 中如果同时存在 template 和 render, 由于存在一个打包过程,其中的模板预编译会生成 render 覆盖原有的 render 函数

在 vue 中如果同时存在 template 和 render,一定是以 render 为准

虚拟 DOM 树会最终生成为真实的 DOM 树

在这里插入图片描述

vue通过以下逻辑生成vnode tree:

在这里插入图片描述

注意:虚拟节点树必须是单根的

注入

在这里插入图片描述

vue会将以下配置注入到vue实例:

  • data:和界面相关的数据
  • computed:通过已有数据计算得来的数据,将来详细讲解
  • methods:方法

模板中可以使用vue实例中的成员

为了防止名称冲突。因为会将data中数据代理给vue,假如说我们自己写的data名称和vue中自带的属性冲突了,那么就会覆盖vue内部的属性,所以vue会把自己内部的属性成员名称前加上 或 , 如 果 加 上 的 是 或_,如果加上的是 或,​如果加上的是,代表是我们可以使用的,如果加上的是_,是vue自己内部使用的方法或属性,我们不需要调用

挂载

将生成的真实 DOM 树,放置到某个元素位置,称之为挂载

挂载的方式:

1.通过el:"CSS选择器"进行配置

2.通过vue实例.$mount(“css选择器”)进行配置

完整流程

  • 实例被创建: new Vue()
  • 注入完成之后才会有响应式,能监听到数据变化
  • 编译生成虚拟 DOM 树:首先找 render 函数,没有就找模板把它生成 render,最后运行 render,生成虚拟 DOM 树
  • 挂载完成:页面上显示

在这里插入图片描述

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注编程网的更多内容!

--结束END--

本文标题: Javascript虚拟DOM详解

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

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

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Javascript虚拟DOM详解
    目录什么是虚拟 dom?为什么需要虚拟dom?虚拟dom是如何转换为真实dom的?模板和虚拟dom的关系注入挂载完整流程总结 什么是虚拟 dom? 虚拟 dom 本质上就是一个普通的...
    99+
    2024-04-02
  • JS前端开发模拟虚拟dom转真实dom详解
    目录引言虚拟dom的介绍虚拟dom转换真实dom总结引言 经常使用Vue或React的小伙伴肯定对虚拟dom这个词不陌生,虚拟dom的设计是推进前端框架发展的一大变革。今天带大...
    99+
    2023-01-10
    JS模拟虚拟dom转真实dom 虚拟dom转真实dom
  • Vue源码分析之虚拟DOM详解
    为什么需要虚拟dom? 虚拟DOM就是为了解决浏览器性能问题而被设计出来的。例如,若一次操作中有10次更新DOM的动作,虚拟DOM不会立即操作DOM,而是将这10次更新的diff内...
    99+
    2024-04-02
  • Vue虚拟DOM详细介绍
    目录一、什么是虚拟DOM二、为什么需要虚拟DOM三、虚拟DOM介绍一、什么是虚拟DOM 虚拟DOM是对真是DOM的抽象,以JavaScript对象(VNode节点)作为基础的树,用对...
    99+
    2022-11-13
    Vue 虚拟DOM Vue 虚拟DOM原理
  • javascript的虚拟DOM怎么进化为真实DOM
    本篇内容主要讲解“javascript的虚拟DOM怎么进化为真实DOM”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript的虚拟DOM怎么进化为真...
    99+
    2024-04-02
  • react中的虚拟dom和diff算法详解
    虚拟DOM的作用 首先我们要知道虚拟dom的出现是为了解决什么问题的,他解决我们平时频繁的直接操作DOM效率低下的问题。那么为什么我们直接操作DOM效率会低下呢? 比如我们创建一个d...
    99+
    2024-04-02
  • Vue3 如何通过虚拟DOM更新页面详解
    目录引言Vue 虚拟 DOM 执行流程DOM 的创建patch 函数patchElement 函数节点自身属性的更新子元素的更新patchChildren位运算为什么位运算性能更好如...
    99+
    2024-04-02
  • 虚拟DOM是什么
    这篇文章主要介绍了虚拟DOM是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇虚拟DOM是什么文章都会有所收获,下面我们一起来看看吧。Snabbdom 是一个虚拟 DOM 实...
    99+
    2024-04-02
  • JavaScript的DOM事件详解
    目录1、事件对象2、事件流3、事件委托4、综合案例总结1、事件对象 【获取事件对象】 什么是事件对象:是个对象,这个对象里有事件触发时的相关信息。事件对象的语法 元素.addEven...
    99+
    2024-04-02
  • Vue虚拟Dom到真实Dom的转换
    再有一颗树形结构的Javascript对象后, 我们需要做的就是讲这棵树跟真实Dom树形成映射关系。我们先回顾之前的mountComponnet 方法: export funct...
    99+
    2024-04-02
  • vue虚拟Dom-render的源码解析
    这篇文章主要介绍“vue虚拟Dom-render的源码解析”,在日常操作中,相信很多人在vue虚拟Dom-render的源码解析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
    99+
    2024-04-02
  • JavaScript中BOM和DOM详解
    目录BOM(浏览器对象模型) 1. window 获取浏览器c窗口尺寸 2. screen 获取电脑屏幕大小 3. window 开启关闭窗口 4. 浏览器事件 5. locatio...
    99+
    2024-04-02
  • vue.js是不是虚拟DOM
    这篇文章主要讲解了“vue.js是不是虚拟DOM”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue.js是不是虚拟DOM”吧! ...
    99+
    2024-04-02
  • JavaScript操作DOM对象详解
    一、DOM基础 DOM(Document Object Model)即文档对象模型,针对HTML和XML文档的API(应用程序接口)。DOM描绘了一个层次化的节点树,运行开发人员添加...
    99+
    2024-04-02
  • Vue虚拟Dom与真实Dom如何转换
    这篇文章主要讲解了“Vue虚拟Dom与真实Dom如何转换”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue虚拟Dom与真实Dom如何转换”吧!再有一颗树形...
    99+
    2024-04-02
  • 关于Vue虚拟dom问题
    目录一、什么是虚拟dom?二、为什么需要虚拟dom三、虚拟dom是如何转换为真实dom的四、模板和虚拟dom的关系一、什么是虚拟dom? 虚拟dom本质上就是一个普通的JS对象,用于...
    99+
    2024-04-02
  • vue 虚拟DOM快速入门
    目录虚拟 DOM 什么是虚拟 dom 虚拟 dom 的作用 vue 中的虚拟 dom vNode 什么是 vNode vNode 的类型 patch 新增节点 删除节点 更新节点 新...
    99+
    2024-04-02
  • Vue响应式原理与虚拟DOM实现步骤详细讲解
    目录一、什么是响应式系统二、实现原理三、虚拟DOM实现四、总结一、什么是响应式系统 在Vue中,我们可以使用data属性来定义组件的数据。这些数据可以在模板中使用,并且当这些数据发生...
    99+
    2023-05-13
    Vue响应式原理 Vue虚拟DOM
  • Vue虚拟Dom到真实Dom的转换方法
    这篇文章主要介绍“Vue虚拟Dom到真实Dom的转换方法”,在日常操作中,相信很多人在Vue虚拟Dom到真实Dom的转换方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue虚拟Dom到真实Dom的转换方法...
    99+
    2023-06-20
  • react虚拟dom有哪些用处
    这篇文章主要介绍“react虚拟dom有哪些用处”,在日常操作中,相信很多人在react虚拟dom有哪些用处问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”react虚拟dom...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作