返回顶部
首页 > 资讯 > 精选 >怎么在Vue中实现一个虚拟dom
  • 726
分享到

怎么在Vue中实现一个虚拟dom

2023-06-14 10:06:40 726人浏览 泡泡鱼
摘要

怎么在Vue中实现一个虚拟dom?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、什么是虚拟dom?虚拟dom本质上就是一个普通的js对象,用于描述视图的界面结构在vue中

怎么在Vue中实现一个虚拟dom?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

一、什么是虚拟dom?

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

怎么在Vue中实现一个虚拟dom

在vue中,每个组件都有一个render函数,

怎么在Vue中实现一个虚拟dom

没有render找template,没有template找el,有el就会把el.outhtml作为template,然后把这串字符串编译成render函数。
有template就不往下找了。有render同理。

怎么在Vue中实现一个虚拟dom

每个render 函数都会返回一个虚拟dom树,这也就意味着每个组件都对应一棵虚拟DOM树。
也就是说render目的就是创建虚拟dom,这个组件到底要显示啥。
console.log(‘render'); ↓

怎么在Vue中实现一个虚拟dom
怎么在Vue中实现一个虚拟dom

题外:console.dir()可以显示一个对象所有的属性和方法。

怎么在Vue中实现一个虚拟dom

如果没有return,这时候在页面中是不存在真实dom的。
加上return↓

怎么在Vue中实现一个虚拟dom

h函数名字是自定义的,h函数结构,h(标签,{自身属性},[子元素])
子元素继续用h函数建,因为有别的属性
我们在[ ]里面再创建一个子元素

怎么在Vue中实现一个虚拟dom

h函数做了判断,如果不是对象,就是文本节点了,↑认为是省略掉了中间的配置

怎么在Vue中实现一个虚拟dom

在页面内渲染出来。
console.log(vnode);

怎么在Vue中实现一个虚拟dom

h2子元素↓

怎么在Vue中实现一个虚拟dom
怎么在Vue中实现一个虚拟dom

通过.elm对应真实结点

h(‘h2','{{title}}')这种是肯定不行的,必须h(‘h2',this.title)

二、为什么需要虚拟dom

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

生成真实dom在第一次加载的时候没有任何问题,因为无法避免,必要要生成真实dom。
render函数不止生成一次,它是每一次数据变化都要生成。
但是如果在render里用createElement每次都会生成全新的dom元素,开销太大了

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

在一个组件实例首次被渲染时,它先生成虚拟dom树,深度优先遍历结点,setAttribute,然后根据虚拟dom树创建真实dom,并把真实dom挂载到页面中合适的位置,直接替换掉div#app,此时,每个虚拟dom便会对应一个真实的dom。

怎么在Vue中实现一个虚拟dom

是不等于的,因为直接替换掉了div#app

如果一个组件受响应式数据变化的影响,需要重新渲染时,它仍然会重新调用render函数,创建出一个新的虚拟dom树,用新树和旧树对比,通过对比,vue会找到最小更新量,然后更新必要的真实dom节点
这样一来,就保证了对真实dom达到最小的改动。

怎么在Vue中实现一个虚拟dom

通过diff算法查看那两个虚拟dom是不一样的,然后去改动对应结点的真实dom完成效果,保证改动最少,提高效率

四、模板和虚拟dom的关系

怎么在Vue中实现一个虚拟dom

脚手架搭的虚拟dom

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

编译的过程分两步,(babel和webpack都是这么创建的):

将模板字符串转换成为AST(抽象语法树,用树形结构描述我们的东西)将AST转换为render函数

AST↓,提一嘴AST用栈搭建的

怎么在Vue中实现一个虚拟dom

如果使用传统的引入方式(src),则编译时间发生在组件第一次加载时,这称之为运行时编译。再提一嘴,第1步非常耗时。
如果是在vue-cli的默认配置下,编译发生在打包时,这称之为模板预编译。
编译是一个极其耗费性能的操作,预编译可以有效的提高运行时的性能,而且,由于运行的时候已不需要编译,vue-cli在打包时会排除掉vue中的compile模块,以减少打包体积

如果上面不写模板template

怎么在Vue中实现一个虚拟dom
怎么在Vue中实现一个虚拟dom

会报错,但是你可以在vue.config.js配置

module.export={runtimeCompiler:true}

不建议,会加入编译内容,使内容变多。(再提一嘴esbuild和vite加速打包,?没用过)

模板的存在,仅仅是为了让开发人员更加方便的书写界面代码
vue最终运行的时候,最终需要的是render函数,而不是模板,因此,模板中的各种语法,在虚拟dom中都是不存在的,它们都会变成虚拟dom的配置

怎么在Vue中实现一个虚拟dom

等同于

怎么在Vue中实现一个虚拟dom

案例:自动生成目录

现在需要制作一个组件,该组件可以根据其插槽中的内容,自动生成一个目录。

怎么在Vue中实现一个虚拟dom
怎么在Vue中实现一个虚拟dom

关于怎么在Vue中实现一个虚拟dom问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网精选频道了解更多相关知识。

--结束END--

本文标题: 怎么在Vue中实现一个虚拟dom

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

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

猜你喜欢
  • 怎么在Vue中实现一个虚拟dom
    怎么在Vue中实现一个虚拟dom?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、什么是虚拟dom?虚拟dom本质上就是一个普通的JS对象,用于描述视图的界面结构在vue中...
    99+
    2023-06-14
  • 怎么实现一个虚拟DOM算法
    这篇文章主要讲解了“怎么实现一个虚拟DOM算法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么实现一个虚拟DOM算法”吧!即虚拟DOM的diff算法的主体...
    99+
    2024-04-02
  • 怎么在react中实现一个虚拟dom和diff算法
    这篇文章将为大家详细讲解有关怎么在react中实现一个虚拟dom和diff算法,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。虚拟DOM,见名知意,就是假的DOM,我们真实的DOM挂载在页面上...
    99+
    2023-06-14
  • vue如何实现虚拟dom的patch
    这篇文章主要为大家展示了“vue如何实现虚拟dom的patch”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue如何实现虚拟dom的patch”这篇文章吧。具...
    99+
    2024-04-02
  • Vue中简单的虚拟DOM是什么样
    目录1. 一个简单的虚拟DOM长什么样2. Vue中的虚拟DOM长什么样3. Vue中的虚拟DOM实现4. createTextVNode1. 一个简单的虚拟DOM长什么样 其实当今...
    99+
    2022-11-13
    Vue虚拟DOM Vue DOM
  • Vue响应式原理与虚拟DOM如何实现
    本篇内容介绍了“Vue响应式原理与虚拟DOM如何实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、什么是响应式系统在Vue中,我们可以使...
    99+
    2023-07-05
  • javascript的虚拟DOM怎么进化为真实DOM
    本篇内容主要讲解“javascript的虚拟DOM怎么进化为真实DOM”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript的虚拟DOM怎么进化为真...
    99+
    2024-04-02
  • Vue中的虚拟DOM和Diff算法实例分析
    这篇文章主要介绍了Vue中的虚拟DOM和Diff算法实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue中的虚拟DOM和Diff算法实例分析文章都会有所收获,下面我们一起来看看吧。简单介绍一下 虚拟DO...
    99+
    2023-06-29
  • vue怎么实现虚拟滚动
    小编给大家分享一下vue怎么实现虚拟滚动,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!前言移动端网页的日常开发中,偶尔会包含一些渲染长列表的场景.比如某旅游网站需...
    99+
    2023-06-20
  • 基于Vue实现封装一个虚拟列表组件
    目录组件效果属性插槽封装过程滚动条正常显示加载渲染大量数据不卡顿能对列表数据进行操作增删等完整代码待完善正常情况下,我们对于数据都会分页加载,最近项目中确实遇到了不能分页的场景,如果...
    99+
    2023-03-07
    Vue封装虚拟列表组件 Vue 虚拟列表组件 Vue 虚拟列表
  • vue怎么实现虚拟滚动效果
    这篇文章主要讲解了“vue怎么实现虚拟滚动效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue怎么实现虚拟滚动效果”吧!效果图:滚动原理为了理解虚拟滚动...
    99+
    2024-04-02
  • 使用Unity怎么实现一个虚拟键盘功能
    使用Unity怎么实现一个虚拟键盘功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。具体内容如下using UnityEngine;using System...
    99+
    2023-06-09
  • 怎样深入理解vue中的虚拟DOM和Diff算法
    怎样深入理解vue中的虚拟DOM和Diff算法,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。真实DOM的渲染在讲虚拟DOM之前,先说一下真实DOM的渲染。浏览器真实DOM渲...
    99+
    2023-06-22
  • 怎么在vue项目中实现一个竖向表格
    怎么在vue项目中实现一个竖向表格?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。为什么要使用VueVue是一款友好的、多用途且高性能的JavaScript框架,...
    99+
    2023-06-14
  • Vue响应式原理与虚拟DOM实现步骤详细讲解
    目录一、什么是响应式系统二、实现原理三、虚拟DOM实现四、总结一、什么是响应式系统 在Vue中,我们可以使用data属性来定义组件的数据。这些数据可以在模板中使用,并且当这些数据发生...
    99+
    2023-05-13
    Vue响应式原理 Vue虚拟DOM
  • 怎么在java中实现虚拟扩展方法
    这期内容当中小编将会给大家带来有关怎么在java中实现虚拟扩展方法,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Java的优点是什么1. 简单,只需理解基本的概念,就可以编写适合于各种情况的应用程序;2....
    99+
    2023-06-14
  • javascript中怎么实现一个基于DOM的模板引擎
    本篇内容主要讲解“javascript中怎么实现一个基于DOM的模板引擎”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript中怎么实现一个基于DO...
    99+
    2024-04-02
  • 怎么在Vue中使用Canvas实现一个弹幕组件
    本篇文章为大家展示了怎么在Vue中使用Canvas实现一个弹幕组件,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。功能介绍支持循环弹幕弹幕不重叠支持选择轨道数支持弹幕发送使用npm i vue-bar...
    99+
    2023-06-09
  • vue中怎么实现一个弹窗插件
    vue中怎么实现一个弹窗插件,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。popup.vue<template>  ...
    99+
    2024-04-02
  • vue中怎么实现一个换肤功能
    这篇文章给大家介绍vue中怎么实现一个换肤功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1 色值的选取和原则推荐大家看下蚂蚁金服的设计指引,里面对常见的交互和界面设计有一套不错的指...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作