登录  /  注册

react虚拟dom有什么用处

WBOY
发布: 2022-06-28 15:51:25
原创
1936人浏览过
react虚拟dom的用处:1、提升react代码性能,虚拟dom是一个js对象,创建一个js对象消耗的性能和创建一个真实dom要小很多,把创建真实dom替换为创建虚拟dom就会有极大的性能上的提升;2、实现跨端应用,在浏览器端是将虚拟dom转换为一个个的浏览器dom节点,也可以将他转换为原生应用的组件来实现跨端应用。

react虚拟dom有什么用处

本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。

react虚拟dom有什么用处

1.极大的提升了性能

2.它使得跨端应用( React Native )得以实现。在浏览器端是将虚拟DOM转换为一个个的浏览器DOM节点。也可以将他转换为原生应用的组件,跨段应用就实现了。

为什么能提升性能

如果没有虚拟DOM,那么就会直接创建真实的DOM,每次数据改变就会去创建一个真实的DOM,然后真实的DOM比较,再去修改真实的DOM,创建真实DOM是需要消耗很多性能的(因为JS生成DOM树会调用web application级的API,这种级别的API性能损耗是很大的),这样就会非常消耗性能。

有了虚拟DOM就不一样了,虚拟DOM是一个js对象,创建一个js对象消耗的性能和创建一个真实DOM要小很多,把创建真实DOM替换为创建虚拟DOM就会有极大的性能上的提升。

虚拟DOM

虚拟DOM是一个js对象

<div id=&#39;abc&#39;><span>hello world</span></div>//真实DOM
[&#39;div&#39;, {id: &#39;abc&#39;}, [&#39;span&#39;, {}, &#39;hello world&#39;]]//虚拟DOM
登录后复制

页面加载和更新过程

1.state数据

2.jsx模板

3.数据 + 模板生成虚拟DOM

4.用虚拟DOM来生成真实DOM

5.state发生变化

6.数据 + 模板 生成新的虚拟DOM

7.比较原始的虚拟DOM和新的虚拟DOM(diff算法)

8.直接操作DOM,改变不一样的地方

扩展知识:

虚拟DOM的目的是什么?

为了实现按页面中DOM元素的高效更新;

在传统的 Web 应用中,我们往往会把数据的变化实时地更新到用户界面中,于是每次数据的微小变动都会引起 DOM 树的重新渲染。

虚拟DOM的目的是将所有操作累加起来,统计计算出所有的变化后,统一更新一次DOM。

极大的提升了性能

它使得跨端应用( React Native )得以实现。在浏览器端是将虚拟DOM转换为一个个的浏览器DOM节点。也可以将他转换为原生应用的组件,跨段应用就实现了。

DOM和虚拟DOM的区别

1,虚拟DOM不会进行排版与重绘操作

2,虚拟DOM进行频繁修改,然后一次性比较并修改真实DOM中需要改的部分(注意!),最后并在真实DOM中进行排版与重绘,减少过多DOM节点排版与重绘损耗

3,真实DOM频繁排版与重绘的效率是相当低的

4,虚拟DOM有效降低大面积(真实DOM节点)的重绘与排版,因为最终与真实DOM比较差异,可以只渲染局部

【相关推荐:javascript视频教程web前端

以上就是react虚拟dom有什么用处的详细内容,更多请关注php中文网其它相关文章!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 //m.sbmmt.com/ All Rights Reserved | php.cn | 湘ICP备2023035733号