当前位置: 首页 > news >正文

说说Real DOM和Virtual DOM的区别?优缺点?

说说Real DOM和Virtual DOM的区别?优缺点?

  • Real DOM(真实的DOM)
    • 真实dom的优缺点?
  • Virtual DOM(虚拟的DOM)
    • 虚拟dom的优缺点?
  • 两者的区别


Real DOM(真实的DOM)

在页面渲染出的每个节点都是一个真实的DOM结构

<div class="root"><h1>hello Real </h1>
</div>

这个就是真实的dom

真实dom的优缺点?

​优点:
​ 1. 直接操作HTML,易用
缺点:
​ 1. 解析速度慢,效率低,内存占用量高
​ 2. 性能差:频繁操作真实DOM,导致重绘、回流

Virtual DOM(虚拟的DOM)

虚拟dom的优缺点?

<h1 className="hClass">hello world</h1>

这是虚拟dom的写法
JSX实际是一种语法糖,在使用过程中会被babel进行编译,转化成JS代码,上面的虚拟DOM转换如下:

const vDom = React.createElement('h1',{{className:'hClass'},'hello world'
)

他一共有三个参数

第一个参数是 标签名,例如h1、div等;
第二个参数是对象,里面存放着标签的一些属性,如class、id等;
第三个参数是节点中的文本

​ 优点:
​ 1. 减少真实dom的频繁更新,减少重绘回流、占用内存少
​ 2. 跨平台:一套react代码可以多端运行
​ 缺点:
​ 1. 页面首次渲染时,由于多一层虚拟dom的计算,速度比正常慢些

两者的区别

1.虚拟dom不会进行重绘和回流,而真实dom会频繁重排与重绘
2.虚拟dom的总损耗是”虚拟dom的增删改+真实dom的差异增删改+重排“;真实dom的消耗是”真实dom全部增删改+重排“

http://www.lryc.cn/news/5927.html

相关文章:

  • 使用脚本以可读的 JSON 格式显示 curl 命令输出
  • 计算机网络9:HTTP和HTTPS的区别
  • Spring+SpringMVC+SpringBoot+MyBatis面试题
  • ContextCapture Master 倾斜摄影测量实景三维建模技术
  • MySQL事务
  • CData Drivers for Acumatica
  • 智慧税务+数据可视化:企业财务管理告别难题
  • Ansible中常用的模块
  • 问:你是如何进行react状态管理方案选择的?
  • 【华为OD机试真题 java、python、jsNode】任务总执行时长【2022 Q4 100分】
  • react基础
  • 【Spark分布式内存计算框架——Spark SQL】2. SparkSQL 概述(上)
  • Kubeadm搭建K8S
  • 【技术分享】搭建java项目引入外部依赖教程
  • 算法 ——世界 二
  • 数据治理CDGP选择题 4
  • 动态规划之01背包问题和完全背包问题
  • MATLAB算法实战应用案例精讲-【图像处理】数字图像灰度化(附Java、python、matlab和opencv代码实现)
  • Linux(强大的yum命令)
  • 28.结语
  • ICRS、GCRS、CIRS、TIRS和ITRS坐标系统简介
  • 你是真的“C”——详解结构体知识点
  • 2023新华为OD机试题 - 单词接龙(JavaScript) | 刷完必过
  • 第一章 一般错误信息 - 错误代码 0 到 99
  • MyBatis 之一(概念、创建项目、操作模式、交互流程)
  • 学习笔记:文件
  • 高考结束了以后应该做的事情(个人经历的总结)
  • 蓝桥杯:k倍区间
  • 【思维模型】概率思维的价值:找到你的人生算法!打开你的人生格局!实现认知跃迁!
  • API文档自动生成工具